RecyclerView搭配ItemTouchHelper实现长按拖拽、滑动删除

ItemTouchHelper是一个支持RecyclerView滑动删除、长按拖拽的一个工具类,使用它我们可以装B无止境,提高用户体验。

长按拖拽的效果

长按拖拽 滑动删除

ItemTouchHelper使用中常见的一些方法

使用ItemTouchHelper我们需要自定义一个类继承ItemTouchHelper.Callback实现它的几个重要的构造方法

  • public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder),这个方法返回RecyclerView的Item可以滑动、拖拽的方向,dragFlags是拖拽的方向,swipeFlags是滑动。可以根据不同的需求定义滑动、拖拽的方向。
@Override
    public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
        RecyclerView.LayoutManager manager = recyclerView.getLayoutManager();
        int dragFlags;
        if (manager instanceof GridLayoutManager || manager instanceof StaggeredGridLayoutManager) {
            //网格布局管理器允许上下左右拖动
            dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN | ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
        } else {
            //其他布局管理器允许上下拖动
            dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
        }
        return makeMovementFlags(dragFlags, 0);
    }
  • public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target),拖拽到新位置时候的回调方法,这里通过接口回调将开始position和结束position通知给到使用的地方,让其进行数据处理。
@Override
    public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
        //不同Type之间不允许移动
        if (viewHolder.getItemViewType() != target.getItemViewType()) {
            return false;
        }
        if (onItemDragListener != null) {
            onItemDragListener.onItemMove(viewHolder.getAdapterPosition(), target.getAdapterPosition());
        }
        return true;
    }
  • public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction),当用户左右滑动的时候执行的方法,这里通过接口回调将滑动的Item的position通知到调用者。
@Override
    public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
        if (onItemSwipeListener != null) {
            onItemSwipeListener.onItemSwiped(viewHolder.getAdapterPosition());
        }
    }
  • public boolean isLongPressDragEnabled(),是否支持长按拖拽,默认值为true。
@Override
  public boolean isLongPressDragEnabled() {
      return super.isLongPressDragEnabled();
  }
  • public boolean isItemViewSwipeEnabled(),是否支持滑动,默认值为true。
@Override
   public boolean isItemViewSwipeEnabled() {
       return super.isItemViewSwipeEnabled();
   }

项目完整代码ItemTouchHelper

你可能感兴趣的:(RecyclerView,Android)