Recyclerview的条目点击事件

自定义的Adapter


public class GoodAdapter extends RecyclerView.Adapter<GoodHolder> implements View.OnClickListener {
    Context context;
    List<GoodBean.DataBean> data;
    private OnItemClickListener onItemClickListener=null;


    public GoodAdapter(Context context, List<GoodBean.DataBean> data, OnItemClickListener onItemClickListener) {
        this.context=context;
        this.data=data;
        this.onItemClickListener=onItemClickListener;
    }

    @Override
    public GoodHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(context).inflate(R.layout.good_list_layout, parent, false);
        GoodHolder goodHolder = new GoodHolder(view);
        view.setOnClickListener(this);

        return goodHolder;
    }

    @Override
    public void onBindViewHolder(GoodHolder holder, int position) {
        //赋值
        String[] split = data.get(position).getImages().split("\\|");
        //设置图片
        Glide.with(context).load(split[0]).into(holder.getImage());
        //设置标题
        holder.getText_title().setText(data.get(position).getTitle());
        //设置价格
        holder.text_price.setText("¥"+data.get(position).getPrice());
        //设置tag给回调的参数当中
        holder.itemView.setTag(position);

    }

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

    @Override
    public void onClick(View v) {

        onItemClickListener.onItemClick(v, (int) v.getTag());

    }


}

Avtivity


public class SearchActivity extends AppCompatActivity {

  

public OnItemClickListener onItemClickListener = new OnItemClickListener() {
    @Override
    public void onItemClick(View view, int position) {
        //i为当前条目

     } 
  
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_search);
}

}


自定义接口

public interface OnItemClickListener {
    void onItemClick(View view , 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、付费专栏及课程。

余额充值