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