ItemTouchHelper的使用

本文介绍了一个用于RecyclerView的实用工具类,该类支持滑动删除和拖拽功能。通过ItemTouchHelper.SimpleCallback实现拖拽和滑动操作,并详细展示了如何在RecyclerView中应用此工具类。

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

一个支持RecyclerView滑动删除和拖拽的实用工具类

1.类简单的实现及说明

//构造函数需要传一个Callback,有一个简单实现类
//ItemTouchHelper.SimpleCallback需要两个参数,第一个表示拖拽的方向,
//第二个表示移动的方向
ItemTouchHelper mHelper = new ItemTouchHelper(new ItemTouchHelper.SimpleCallback(ItemTouchHelper.UP|ItemTouchHelper.DOWN|ItemTouchHelper.LEFT|ItemTouchHelper.RIGHT,ItemTouchHelper.LEFT|ItemTouchHelper.RIGHT) {
//拖动的方法
        @Override
        public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
            Collections.swap(mStrings, viewHolder.getAdapterPosition(), target.getAdapterPosition());
            mAdapter.notifyItemMoved(viewHolder.getAdapterPosition(),  target.getAdapterPosition());
            return true;
        }
//移动的方法
        @Override
        public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
            int pos = viewHolder.getAdapterPosition();
            mStrings.remove(pos);
            mAdapter.notifyItemRemoved(pos);
        }

        @Override
        public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
        //表示拖拽的方向,为零表示不能拖动
            int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
        //表示移动的方向,为零表示不能移动
            int swipeFlags = 0;//ItemTouchHelper.START | ItemTouchHelper.END;
            return makeMovementFlags(dragFlags,swipeFlags);
        }
        //绘制item,actionState有三种状态SWIPE(滑动)、IDLE(静止)、DRAG(拖动)我们可以根据相应的状态来绘制Item的一些效果
        @Override
        public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
            super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);
            if(actionState==ItemTouchHelper.ACTION_STATE_SWIPE){
                final float alpha = 1 - Math.abs(dX) / (float)viewHolder.itemView.getWidth();
                viewHolder.itemView.setAlpha(alpha);
            }else if(actionState==ItemTouchHelper.ACTION_STATE_IDLE){
                viewHolder.itemView.setAlpha(0.5f);
            }
        }
        //拖动的时候,位于其他item上的时候绘制
        @Override
        public void onChildDrawOver(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
            super.onChildDrawOver(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);
            if(actionState==ItemTouchHelper.ACTION_STATE_SWIPE){
                final float alpha = 1 - Math.abs(dX) / (float)viewHolder.itemView.getWidth();
                viewHolder.itemView.setAlpha(0.1f);
            }else if(actionState==ItemTouchHelper.ACTION_STATE_IDLE){
                viewHolder.itemView.setAlpha(0.1f);
            }else if(actionState==ItemTouchHelper.ACTION_STATE_DRAG){
                final float alpha = 1 - Math.abs(dX) / (float)viewHolder.itemView.getWidth();
                viewHolder.itemView.setAlpha(0.5f);
            }
        }
    });

2.应用到RecyclerView上

mHelper.attachToRecyclerView(mRecyclerView);

3.效果图

用的是这个博客的效果图图片来源地址
这里写图片描述
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值