RecyclerView带有动画的多条目删除

先看一张效果图,这个删除动画用的是RecyclerView默认的。

按照一般的基本思路,肯定是首先对数据源进行for循环,如果这个条目被选中,则进行删除。这是我刚开始的代码片段。

for (int i = 0; i < mDatas.size(); i++) {
       Patient patient = mDatas.get(i);
       if (patient.isChecked()) {
         mDatas.remove(i);//先从数据源中进行移除
         adapter.notifyItemRemoved(i);//在调用适配器的删除
         adapter.notifyItemRangeChanged(0, mDatas.size());//进行条目的刷新
       }
}

但当我操作删除的时候,出现了删除不彻底的问题,就是我选择了三条,但只删除掉了两条,我感觉应该是索引除了问题。但我并没有深究,感觉这种方法行不通。

百度了一番之后,找到一种让我豁然开朗的解决方案。通过forr循环,也就是倒着循环。

 for (int i = mDatas.size() - 1; i >= 0; i--) {
       Patient patient = mDatas.get(i);
       if (patient.isChecked()) {
           mDatas.remove(i);
           adapter.notifyItemRemoved(i);
           adapter.notifyItemRangeChanged(0, mDatas.size());
       }
}

这样就是从后往前删除,这样索引就不会出现问题。也达到了自己预期的效果。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果在 Android `RecyclerView` 中使用默认的动画效果时出现锯齿,可以尝试以下解决方案: 1. 设置 `RecyclerView` 的 `clipToPadding` 属性为 `false`。 ```xml <androidx.recyclerview.widget.RecyclerView android:layout_width="match_parent" android:layout_height="match_parent" android:clipToPadding="false" /> ``` 2. 在 `RecyclerView` 中使用 `ItemDecoration`。 ```kotlin class ItemDecoration : RecyclerView.ItemDecoration() { override fun getItemOffsets( outRect: Rect, view: View, parent: RecyclerView, state: RecyclerView.State ) { outRect.set(0, 0, 0, 1) // 设置底部分割线,数值可以根据自己的需求调整 } override fun onDraw( canvas: Canvas, parent: RecyclerView, state: RecyclerView.State ) { super.onDraw(canvas, parent, state) val childCount = parent.childCount for (i in 0 until childCount) { val child = parent.getChildAt(i) val params = child.layoutParams as RecyclerView.LayoutParams val left = child.left + params.leftMargin val right = child.right + params.rightMargin val top = child.bottom + params.bottomMargin val bottom = top + 1 // 设置底部分割线,数值可以根据自己的需求调整 canvas.drawRect(left.toFloat(), top.toFloat(), right.toFloat(), bottom.toFloat(), paint) } } private val paint = Paint().apply { color = Color.parseColor("#e5e5e5") // 分割线颜色 style = Paint.Style.FILL } } ``` 3. 使用第三方库 `RecyclerView Animators`。 ```gradle dependencies { implementation 'jp.wasabeef:recyclerview-animators:4.0.2' } ``` ```kotlin val animator = SlideInUpAnimator(OvershootInterpolator(1f)) recyclerView.itemAnimator = animator ``` 希望以上解决方案可以帮助到你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值