Recyclerview--两行代码轻松添加点击选中效果

  • 前言

简单的实现Recyclerview选中效果,开发中很常见,比如点击item,后面加上选择按钮,亦或者类似CheckBox效果,可以用很少几行代码实现

  • 实现

直接贴代码,布局很简单,一个文字,后面一个选择按钮

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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="45dp"
    android:layout_margin="5dp"
    android:gravity="center"
    android:orientation="horizontal">

    <TextView
        android:id="@+id/tv_state"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="center"
        android:layout_marginLeft="5dp"
        android:layout_marginRight="10dp"
        android:gravity="center"
        android:textColor="@color/state_visibility"
        android:textSize="18sp"
        tools:text="@string/state" />

    <ImageView
        android:id="@+id/iv_selected"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
          android:visibility="invisible"
        android:src="@drawable/icon_selected" />
</LinearLayout>```

实现选择功能,在Adapter中

/**

  • Author : ddz
  • Creation time : 2017/3/1 17:08
  • Fix time : 2017/3/1 17:08
    */

public class CheckStateAdapter extends RecyclerView.Adapter<CheckStateAdapter.StateHolder> {

private Context context;
private String[] arrayState;
private int selectedPosition = -5; //默认一个参数

public CheckStateAdapter(@NonNull String[] arrayState, Context context) {
    this.context = context;
    this.arrayState = arrayState;
}

@Override
public StateHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    return new StateHolder(LayoutInflater.from(context).inflate(R.layout.state_item, parent, false));
}

@Override
public void onBindViewHolder(StateHolder holder, int position) {
    if (null == arrayState) return;
    holder.itemView.setSelected(selectedPosition == position);
    if (selectedPosition == position) {
        holder.ivSelected.setVisibility(View.VISIBLE);
    } else {
        holder.ivSelected.setVisibility(View.INVISIBLE);
    }
    holder.tvState.setText(arrayState[position]);
    holder.itemView.setOnClickListener(view -> {
        onItemClickListener.OnItemClick(view, holder, holder.getAdapterPosition()); 
        selectedPosition = position; //选择的position赋值给参数,
        notifyItemChanged(selectedPosition);//刷新当前点击item
    });
}



@Override
public int getItemCount() {
    return arrayState.length == 0 ? 0 : arrayState.length;
}

public void updateData(String[] airPortModels) {
    if (null != arrayState) {
        selectedPosition = -5;
        arrayState = null;
        arrayState = airPortModels;
        notifyDataSetChanged();
    }
}


public class StateHolder extends RecyclerView.ViewHolder {
    @BindView(R.id.tv_state)
    TextView tvState;
    @BindView(R.id.iv_selected)
    ImageView ivSelected;

    public StateHolder(View itemView) {
        super(itemView);
        ButterKnife.bind(this, itemView);
    }
}

private OnItemClickListener onItemClickListener;

public interface OnItemClickListener {  //定义接口,实现Recyclerview点击事件
    void OnItemClick(View view, StateHolder holder, int position);
}


public void setOnItemClickListener(OnItemClickListener onItemClickListener) {   //实现点击
    this.onItemClickListener = onItemClickListener;
}

}

item点击时,就可以简单实现点击选中效果


作者:T9的第三个三角
链接:https://www.jianshu.com/p/088e93832268
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值