RecyclerView的拖动和滑动

本文介绍了一种简单有效的方法,利用ItemTouchHelper为RecyclerView添加拖拽排序与滑动删除的功能。ItemTouchHelper作为Android兼容包的一部分,通过实现ItemTouchHelper.Callback接口可以轻松地为RecyclerView添加交互特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在安卓中,有许多关于如何使用RecyclerView实现“drag & drop”与swipe-to-dismiss”的教程,库和例子。即使现在已经有了新的,更优的实现方式,大多数仍然是使用老旧的View.OnDragListener以及Roman Nurik在SwipeToDismiss中所使用的方法。很少有人使用新的api,反而要么经常依赖于GestureDetectors和onInterceptTouchEvent,要么实现方式很复杂。实际上,在RecyclerView上添加拖动特性有一个非常简单的方法。这个方法只需要一个类,并且它也是Android 兼容包的一部分,它就是:

ItemTouchHelper

ItemTouchHelper是一个强大的工具,它处理好了关于在RecyclerView上添加拖动排序与滑动删除的所有事情。它是RecyclerView.ItemDecoration的子类,也就是说它可以轻易的添加到几乎所有的LayoutManager和Adapter中。它还可以和现有的item动画一起工作,提供受类型限制的拖放动画等等。

使用 ItemTouchHelper 和 ItemTouchHelper.Callback

要使用ItemTouchHelper,你需要创建一个ItemTouchHelper.Callback。这个接口可以让你监听“move”与 “swipe”事件。这里还是控制view被选中的状态以及重写默认动画的地方。如果你只是想要一个基本的实现,有一个帮助类可以使用:SimpleCallback,但是为了了解其工作机制,我们还是自己实现。

public class SimpleItemTouchHelperCallback extends ItemTouchHelper.Callback {
  
     
    public SimpleItemTouchHelperCallback(ItemTouchHelperAdapter adapter) {
            }
     
    @Override
    public boolean isLongPressDragEnabled() {
        return true;
    }
  
    @Override
    public boolean isItemViewSwipeEnabled() {
        return true;
    }
  
    @Override
    public int getMovementFlags(RecyclerView recyclerView, ViewHolder viewHolder) {//重写getMoivementFlags()方法来指
        int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;    //定可以支持的拖动和滑动的方向。使用
        int swipeFlags = ItemTouchHelper.START | ItemTouchHelper.END; //helperItemToooouchHelper.makeMovementFlages
        return makeMovementFlags(dragFlags, swipeFlags);           //(int,int)来构造返回的flag。上下为drag,左右为swipe
    }
  
    @Override
    public boolean onMove(RecyclerView recyclerView, ViewHolder viewHolder,//拖动事件响应,重新排序 
            ViewHolder target) {
        int fromPosition = viewHolder.getAdapterPosition)();
	int targetPosition = target.getAdapterPosition();
	Collections.swap(mItems,fromPosion,targetPosition);
	notifyItemMove(fromPosition,targetPosition);
        return true;
    }
  
    @Override
    public void onSwiped(ViewHolder viewHolder, int direction) {//左右滑动事件响应,删除item
        int position = viewHOlder.getAdapterPosition();
	mItems.remove(position);
	notifyItemRemoved(position);
    }
  
}



Callback准备好了之后,我们就可以创建我们的ItemTouchHelper并调用attachToRecyclerView(RecyclerView) 了

ItemTouchHelper.Callback callback = 
    new SimpleItemTouchHelperCallback(adapter);
ItemTouchHelper touchHelper = new ItemTouchHelper(callback);
touchHelper.attachToRecyclerView(recyclerView);


运行之后,你可以看到如下的效果:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值