RecycleViewItem拖拽

今天主要讲下RecycleView实现Item的拖拽和侧滑删除

项目参照

https://github.com/iPaulPro/Android-ItemTouchHelper-Demo

我的项目

https://github.com/Maliola/DragItem

我的项目是在她的基础上延伸了自定义点击颜色和切换可替换位置的功能。

在实现该功能需要借助ItemTouchHelper,v7包里带有这个类所以可以直接看起源码。本文是主要对于ItemTouchHelper内部类Callback继承和处理。

自定义一个SimpleItemTouchHelperCallback继承ItemTouchHelper.Callback。主要实现以下几个重要方法。

1. getMovementFlags大家可以去看下源码,该方法的大体意思是获取事件的flag然后进行相应的操作,简单说就是设置滑动和侧滑的内容。

public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
    // Set movement flags based on the layout manager
    if (recyclerView.getLayoutManager() instanceof GridLayoutManager) {
        final int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN | ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
        final int swipeFlags = 0;
        return makeMovementFlags(dragFlags, swipeFlags);
    } else {
        final int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
        final int swipeFlags = ItemTouchHelper.START | ItemTouchHelper.END;
        return makeMovementFlags(dragFlags, swipeFlags);
    }
}
2. onMove 判断移动前后的itemViewType是否一致,不一致则调用adapter的ItemMove。当前adapter是在构造器里传进来的
public SimpleItemTouchHelperCallback(ItemTouchHelperAdapter adapter) {
    mAdapter = adapter;
}

这里的adapter是自定义的接口,你用时可以新建adapter直接继承该接口即可使用调用的方法。

3. onSwiped是判断是否消失的方法。

@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int i) {
    // Notify the adapter of the dismissal
    mAdapter.onItemDismiss(viewHolder.getAdapterPosition());
}
4. onChildDraw则是处理一些动效的,该方法里处理的就是在侧滑时item出去时透明度的变化。

@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
    if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE) {
        // Fade out the view as it is swiped out of the parent's bounds
        final float alpha = ALPHA_FULL - Math.abs(dX) / (float) viewHolder.itemView.getWidth();
        viewHolder.itemView.setAlpha(alpha);
        viewHolder.itemView.setTranslationX(dX);
    } else {
        super.onChildDraw(c
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值