RecyclerView 多条目 包括点击事件

点击打开链接

导入依赖

compile 'com.android.support:recyclerview-v7:25.3.1'
//效果

主布局文件
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.bwei.administrator.dianshang.activity.ThridActivity">

    <android.support.v7.widget.RecyclerView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/recycle_view"
        >

    </android.support.v7.widget.RecyclerView>


</android.support.constraint.ConstraintLayout>
=============mainActivity================
private RecyclerView recyclerView;
private List<String> list;
private MoreItemAdapter ma;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_thrid);
    //获取控件
    recyclerView = (RecyclerView) findViewById(R.id.recycle_view);
     //数据源
    list = new ArrayList<>();
     for (int i=0;i<1000;i++){
         list.add("条目"+i);
     }
     //布局管理
     recyclerView.setLayoutManager(new LinearLayoutManager(ThridActivity.this));


    //创建适配器
       ma = new MoreItemAdapter(list,ThridActivity.this);
      recyclerView.setAdapter(ma);

    //条目的点击事件   接口回调
        ma.setOnitemClickListner(new OnItemClickListner() {
            @Override
            public void onItemClick(int position) {
                Toast.makeText(ThridActivity.this,"点击了"+list.get(position),Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onItemLongClick(int position) {
                Toast.makeText(ThridActivity.this,"长按了"+list.get(position),Toast.LENGTH_SHORT).show();
            }
        });



}
=============适配器================
List<String> list;
Context context;
private final int text_Only=0;
private final int IMAGE_LEFT=1;
private final int IMAGE_RIGHT=2;
private OnItemClickListner onItemClickListner;


public MoreItemAdapter(List<String> list, Context context) {
    this.list = list;
    this.context = context;
}

@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        RecyclerView.ViewHolder holder=null;
        View view;
        switch (viewType){
            case text_Only:
                view= LayoutInflater.from(context).inflate(R.layout.water_item,parent,false);
               holder=new Text_Only(view);
                break;
            case IMAGE_LEFT:
                view= LayoutInflater.from(context).inflate(R.layout.image_left,parent,false);
                holder=new Image_left(view);
                break;
            case IMAGE_RIGHT:
                view= LayoutInflater.from(context).inflate(R.layout.image_right,parent,false);
                holder=new Image_Right(view);
                break;
        }
    return holder;
}

@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, final int position) {
    //判断方法返回值
    if(getItemViewType(position)==text_Only){
        ((Text_Only)holder).tv.setText(list.get(position));
        //条目点击
        ((Text_Only)holder).tv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                onItemClickListner.onItemClick(position);
            }
        });
        ((Text_Only)holder).tv.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {
                onItemClickListner.onItemLongClick(position);
                return true;
            }
        });
    }else if(getItemViewType(position)==IMAGE_LEFT){
        ((Image_left)holder).tv.setText(list.get(position));
    }else{
        ((Image_Right)holder).tv.setText(list.get(position));
    }


}

@Override
public int getItemCount() {
    return list.size();
}

@Override
public int getItemViewType(int position) {
    if(position%3==0){
        return text_Only;
    }else if(position%3==1){
        return IMAGE_LEFT;
    }else{
        return IMAGE_RIGHT;
    }


}

public void setOnitemClickListner(OnItemClickListner onItemClickListner) {
    this.onItemClickListner = onItemClickListner;

    //onItemClickListner.onItemClick();
}
==========接口===========
public interface OnItemClickListner {
    public void onItemClick(int position);
    public void onItemLongClick(int position);

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值