Android实现RecyclerView侧滑删除和长按拖拽

本文介绍了如何在Android中使用RecyclerView实现拖拽排序和侧滑删除功能。通过导入RecyclerView,创建JavaBean,设置布局和触摸事件,编写适配器,最后添加触摸事件处理来实现这一效果。示例代码展示了线性布局和网格布局两种情况下的实现方式。
摘要由CSDN通过智能技术生成

RecyclerView实现拖拽排序侧滑删除效果


事先说明:

RecyclerView是ListView的升级版,使用起来比ListView更规范,而且功能和动画可以自己添加,极容易扩展,同样也继承了ListView复用convertView和ViewHolder的优点。


思路分析:

1、导包、在布局中使用RecyclerView

2、需要一个JavaBean用来存储展示信息

3、需要一个填充RecyclerView的布局文件

4、在代码中找到RecyclerView,并为其绑定Adapter和触摸事件

5、适配器的编写、触摸事件的处理

总体上跟ListView是一样的,就是换了一种代码风格


思路图解:



效果一(线性布局):                                                                         效果二(网格布局):

   


步骤一:RecyclerView是在support.v7包,Android Studio则是recyclerview这个包



步骤二:创建布局文件,使用recyclerview

[java] view plain copy
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:background="#F4F4F3"  
  6.     android:orientation="vertical"  
  7.     tools:context="com.handsome.app3.MainActivity">  
  8.   
  9.     <ImageView  
  10.         android:layout_width="match_parent"  
  11.         android:layout_height="wrap_content"  
  12.         android:background="@drawable/top" />  
  13.   
  14.     <android.support.v7.widget.RecyclerView  
  15.         android:id="@+id/rv"  
  16.         android:layout_width="match_parent"  
  17.         android:layout_height="match_parent"  
  18.         android:layout_weight="1" />  
  19.   
  20.     <ImageView  
  21.         android:layout_width="match_parent"  
  22.         android:layout_height="wrap_content"  
  23.         android:background="@drawable/bottom" />  
  24. </LinearLayout>  

步骤三:创建一个javaBean,存储item的信息

[java] view plain copy
  1. public class Message {  
  2.   
  3.     private String username;  
  4.     private String time;  
  5.     private String message;  
  6.     private int img_id;  
  7.   
  8.     public Message(String username, String time, String message, int img_id) {  
  9.         this.username = username;  
  10.         this.time = time;  
  11.         this.message = message;  
  12.         this.img_id = img_id;  
  13.     }  
  14.   
  15.     public String getUsername() {  
  16.         return username;  
  17.     }  
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个问题其实是一个编码问题。原本这个问句是“如何recyclerview侧滑删除item”,但是被编码转换了一下。如果要回答,应该是如下: 使用RecyclerView可以通过实现ItemTouchHelper.Callback类来实现侧滑删除item的效果。在实现ItemTouchHelper.Callback类中,可以通过onSwiped()方法实现侧滑删除item。在onSwiped()方法中,可以调用RecyclerView.Adapter的notifyItemRemoved()方法来通知RecyclerView移除该item。 ### 回答2: RecyclerViewAndroid上一个强大的列表控件。它提供了不同于ListView和GridView的Item视图回收机制以及更灵活的布局管理,同时也支持ItemTouchHelper类来实现方便的侧滑删除item的功能。 ItemTouchHelper是Android Support Library中为RecyclerView提供的一个辅助类,主要是用于支持RecyclerView中的拖拽和滑动事件。为了实现RecyclerView侧滑删除item的功能,我们需要使用ItemTouchHelper类,并实现ItemTouchHelper.Callback的各个方法(onMove、onSwiped等): 1. onMove():该方法用于处理RecyclerView拖拽事件,通常用于实现Item的移动、排序等,我们可以在该方法中添加自己的代码,实现列表Item的移动。 2. onSwiped():该方法用于处理RecyclerView中的滑动事件,通常用于实现列表Item的删除等功能,我们可以在该方法中添加自己的代码,实现Item删除的操作。 在我们实现侧滑删除Item的过程中,上述两个方法都需要实现。其中,onSwiped()方法中,我们通常会使用adapter的remove()方法将Item从列表中移除。 具体实现过程如下: 1.创建一个SwipeToDeleteCallback类,并继承自ItemTouchHelper.Callback类。 public class SwipeToDeleteCallback extends ItemTouchHelper.Callback { //实现 onMove() 方法 @Override public boolean onMove(@NonNull RecyclerView recyclerView, @NonNull RecyclerView.ViewHolder viewHolder, @NonNull RecyclerView.ViewHolder target) { return false; } //实现 onSwiped() 方法 @Override public void onSwiped(@NonNull RecyclerView.ViewHolder viewHolder, int direction) { //从数据源中移除 Item //adapter.remove(viewHolder.getAdapterPosition()) } //其他的实现方法... } 2.在onCreate()方法中创建SwipeToDeleteCallback实例,并将其绑定到RecyclerView上。 SwipeToDeleteCallback swipeHandler = new SwipeToDeleteCallback(this); ItemTouchHelper itemTouchHelper = new ItemTouchHelper(swipeHandler); itemTouchHelper.attachToRecyclerView(recyclerView); 3.在RecyclerViewAdapter实现remove()方法,并在onBindViewHolder()方法中为每个Item添加GestureDetector。通过监听GestureDetector的滑动事件,判断当前Item是否向右滑动,并根据滑动的方向调用ItemTouchHelper.Callback的onSwiped()方法。 public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { //数据源 List<String> mDataList = new ArrayList<>(); //添加Item操作 public void addItem(String item) { mDataList.add(item); notifyItemInserted(mDataList.size() - 1); } //移除 Item 操作 public void remove(int position) { mDataList.remove(position); notifyItemRemoved(position); } // 创建 ViewHolder @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { //创建 Item 布局 View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.list_item, parent, false); return new ViewHolder(view); } // 绑定 ViewHolder @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { //设置 Item 数据 holder.itemText.setText(mDataList.get(position)); //添加 GestureDetector 监听 Item 滑动事件 GestureDetectorCompat gestureDetector = new GestureDetectorCompat(holder.itemView.getContext(), new MyGestureListener(holder)); holder.itemView.setOnTouchListener((view, motionEvent) -> { gestureDetector.onTouchEvent(motionEvent); return true; }); } //获取数据源大小 @Override public int getItemCount() { return mDataList.size(); } //创建 ViewHolder static class ViewHolder extends RecyclerView.ViewHolder { private TextView itemText; ViewHolder(View itemView) { super(itemView); itemText = itemView.findViewById(R.id.item_text); } } //GestureDetector 监听器,用于监听 Item 的滑动事件 class MyGestureListener extends GestureDetector.SimpleOnGestureListener { private final ViewHolder mHolder; MyGestureListener(MyAdapter.ViewHolder holder) { mHolder = holder; } @Override public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { final float xDiff = e2.getX() - e1.getX(); if (Math.abs(xDiff) > 100) { //向右滑动时调用 onSwiped()方法 if (xDiff > 0) { remove(mHolder.getAdapterPosition()); return true; } } return false; } } } 在上述功能实现过程中,我们继承了ItemTouchHelper.Callback来自定义每个Item的拖拽和滑动事件,使用ItemTouchHelper将这个Callback实例与RecyclerView绑定在一起,然后在Adapter中添加了remove()方法,以实现Item的删除功能。最後,我们使用GestureDetector监听Item滑动事件,并根据滑动的方向调用ItemTouchHelper.Callback的onSwiped()方法。 在实现RecyclerView侧滑删除item的过程中,我们还可以对ItemView进行进一步的美化,例如在ItemView左右两侧添加删除和修改按钮等。总之,RecyclerView提供了足够灵活的机制,使得我们能够自由地扩展和定制列表控件的各种功能,为用户提供优秀的使用体验。 ### 回答3: RecyclerViewAndroid官方推出的一个列表控件,它比ListView具有更为灵活和高效的特性,支持数据动态更新、多种布局管理、 ItemTouchHelper操作等,而其支持的滑动操作也极大地方便了用户操作列表数据。针对RecyclerView侧滑删除item,可以通过以下方式实现。 1. ItemTouchHelper ItemTouchHelper是RecyclerView的内置工具类,可实现滑动删除、拖曳排序等操作。通过ItemTouchHelper.onSwiped()回调将删除数据源,再通过适配器的notifyItemRemoved()通知RecyclerView删除某个条目。 2. 自定义ItemDecoration 我们可以通过RecyclerView的ItemDecoration来实现侧滑删除操作,通过自定义一个类继承ItemDecoration并在其onDraw()方法中绘制删除按钮,再通过onTouchEvent()方法实现删除操作,即可实现侧滑删除item。 3. 第三方库 目前市面上也有一些优秀的RecyclerView侧滑删除第三方库,如SwipeMenuRecyclerView、SwipeRecyclerView等。这些库都提供了美观且易于使用的侧滑删除控件,大大降低了开发者的工作量。 总之,RecyclerView侧滑删除功能符合用户的使用习惯,提高了用户的操作效率,是不可或缺的一个功能,希望开发者在设计列表页面时能够注重用户体验,添加RecyclerView侧滑删除功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值