Android学习笔记三十之RecyclerView和CardView实现拖拽和滑动

本文介绍如何在Android中使用RecyclerView和CardView结合实现拖拽及滑动删除功能。通过实现适配器和ItemTouchHelper.Callback接口,以及自定义回调接口和适配器接口,可以轻松实现拖拽和滑动删除。示例代码展示了基本实现过程,并提供了Demo源码下载。
摘要由CSDN通过智能技术生成

Android学习笔记三十之RecyclerView和CardView实现拖拽和滑动

  在上一篇中,我们介绍了SwiperefreshLayout、RecyclerView和CardView,还用着三个控件组合实现了一些效果,下拉刷新也不在需要用第三方的框架,实现的效果也比较符合Google的MD设计,这一节,我们使用RecyclerView和CardView组合实现拖拽和滑动删除的效果。

RecyclerView实现拖拽和滑动删除非常简单,只需要实现下面的三句代码:

     //关联RecyclerView
    ItemTouchHelper.Callback callback=new ItemTouchCallback(dragAdapter);
    ItemTouchHelper itemTouchHelper=new ItemTouchHelper(callback);
    itemTouchHelper.attachToRecyclerView(rv_drag_list);

  我们看到,要实现拖拽和滑动删除需要实现一个适配器和一个回调接口。其中,这个回调接口需要我们自己去实现,重点就是实现的这个回调接口,下面我们具体介绍一下这个自定义的回调接口:

我们自定义一个类,实现ItemTouchHelper.Callback这个接口,先看一下具体的自定义回调接口的源码

package com.example.newapidemo.common;

import android.graphics.Canvas;
import android.support.v7.widget.GridLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.helper.ItemTouchHelper;

/**
 * Created by Devin on 2016/7/15.
 */
public class ItemTouchCallback extends ItemTouchHelper.Callback {
public static final float ALPHA_FULL = 1.0f;
private ItemTouchAdapter itemTouchAdapter;

public ItemTouchCallback(ItemTouchAdapter itemTouchAdapter) {
    this.itemTouchAdapter = itemTouchAdapter;
}

/**
 * 指定可以支持的拖放和滑动的方向
 * List类型的RecyclerView,拖拽只有UP、DOWN
 * Grid类型的则有UP、DOWN、LEFT、RIGHT四个方向
 * <p/>
 * dragFlags 是拖拽标志,swipeFlags是滑动标志,在Grid中把swipeFlags设置为0,表示不处理滑动操作。
 *
 * @param recyclerView
 * @param viewHolder
 * @return
 */
@Override
public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder vie
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值