Android——RecyclerView——使用ItemDragHelper来实现酷炫拖拽效果

本文介绍了如何使用ItemTouchHelper和RecyclerView实现列表的拖拽排序及滑动删除功能。通过自定义ItemTouchHelper.Callback并在关键回调中进行操作,如getMovementFlags、onMove和onSwiped等,可以轻松添加交互效果。此外,还探讨了关于犯罪率下降的有趣观点。
摘要由CSDN通过智能技术生成

参考资料

参考资料1
参考资料2
参考资料3【推荐】

背景介绍

列表控件可以说是我们绝大部分App中都会使用的,为了提升交互乐趣,我们经常需要在列表中加入拖拽、滑动等操作,本篇我将介绍使用ItemDragHelper这个官方提供的交互帮助类来帮助RecyclerView实现这些复杂的交互。

走进ItemTouchHelper

要使用这个类,最关键的步骤是传给它一个ItemTouchHelper.Callback,其它的我们可以不用管。既然它是一个Callback,那么我们可以大概猜到,我们自然就是在它的一些回调函数里做操作了。下面我们就来看看我们需要在哪些回调函数里做操作。
先上个效果图:
拖拽、滑动效果图

public class CustomItemTouchHelperCallback extends ItemTouchHelper.Callback {
   
  private OnItemTouchCallbackListener onItemTouchCallbackListener;

  private boolean canDrag = true;
  private boolean canSwipe = true;

  public CustomItemTouchHelperCallback(OnItemTouchCallbackListener onItemTouchCallbackListener) {
    this.onItemTouchCallbackListener = onItemTouchCallbackListener;
  }

  @Override
  public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
    RecyclerView.LayoutManager layoutManager = recyclerView.getLayoutManager();
    int dragFlags = 0;
    int swipeFlags = 0;
    if (layoutManager instanceof GridLayoutManager) {
      // 如果是Grid布局,则不能滑
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值