android列表侧滑删除&置顶(1)

20210420163551339.gif

这里是使用的第三方依赖库实现,详细的使用教程请访问github官方文档,功能很强大,star超过3.3K,引用官方的一句话“本控件不依赖任何父布局,不是针对 RecyclerView、ListView,而是任意的ViewGroup里的childView都可以使用侧滑(删除)菜单。” SwipeDelMenuLayout

build.gradle(Project)

maven { url “https://jitpack.io” }

build.gradle(module)

implementation ‘com.github.mcxtzhang:SwipeDelMenuLayout:V1.3.0’

重点是他的使用,主要是在适配器的布局当中,我们使用如下父布局控件SwipeMenuLayout即可实现侧滑的效果。两个Button就是侧滑出现的内容。

<?xml version="1.0" encoding="utf-8"?>

<com.mcxtzhang.swipemenulib.SwipeMenuLayout
xmlns:android=“http://schemas.android.com/apk/res/android”
android:layout_width=“match_parent”
android:layout_height=“60dp”
android:clickable=“true”
android:orientation=“horizontal”>








</com.mcxtzhang.swipemenulib.SwipeMenuLayout>

适配器中的代码,就是普通的RecyclerView适配器,我们只需要把删除、置顶的两个点击回调,写2个对应删除、置顶的方法即可。删除方法,就是list集合删除当前的position,然后notifyDataSetChanged一下就可以了,置顶方法就是list集合,添加当前的position到集合的起始位置。

class SampleAdapter(val list: ArrayList): RecyclerView.Adapter<SampleAdapter.ViewHolder>() {
inner class ViewHolder(view:View):RecyclerView.ViewHolder(view){
val tvName:TextView=view.findViewById(R.id.tvName)
val btnTop:TextView=view.findViewById(R.id.btnTop)
val btnDelete:TextView=view.findViewById(R.id.btnDelete)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): SampleAdapter.ViewHolder {
val view=LayoutInflater.from(parent.context).inflate(R.layout.item_sample,parent,false)
return ViewHolder(view)
}

override fun getItemCount()=list.size

override fun onBindViewHolder(holder: SampleAdapter.ViewHolder, position: Int) {
holder.tvName.setText(list.get(position))

//删除按钮
holder.btnDelete.setOnClickListener {
onItemClickDelete.invoke(it,position)
}
//置顶按钮
holder.btnTop.setOnClickListener {
onItemClickTop.invoke(it,position)
}
}

//删除
fun delete(position: Int){
list.removeAt(position)
notifyDataSetChanged()
}
//置顶
fun top(position: Int){
list.add(0,list.removeAt(position))
notifyDataSetChanged()
}

lateinit var onItemClickDelete: (v: View, pos: Int) -> Unit//删除
lateinit var onItemClickTop: (v: View, pos: Int) -> Unit//置顶
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>

<androidx.constraintlayout.widget.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=“.MainActivity”>

<androidx.recyclerview.widget.RecyclerView
android:id=“@+id/rv_sample”
android:layout_width=“match_parent”
android:layout_height=“match_parent”/>

</androidx.constraintlayout.widget.ConstraintLayout>

MainAcivity

class MainActivity : AppCompatActivity() {
private lateinit var rvSample:RecyclerView
override fun onCreate(savedInstanceState: Bundle?) {
MainActivity : AppCompatActivity() {
private lateinit var rvSample:RecyclerView
override fun onCreate(savedInstanceState: Bundle?) {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值