RecyclerView使用ItemTouchHelper

What

**ItemTouchHelper**Google 官方对Item进行拖拽和滑动的工具类

Why

使用ItemTouchHelper可以实现Item拖拽排序,滑动删除等操作

How

  • 效果:

这里写图片描述

1.定义Adapter用到的接口

/**
 * 为Adapter设计的接口,当触发相应事件时,adapter做对应处理
 */
public interface ItemTouchHelper4Adapter  {
    /**
     * 当Item移动时触发
     * @param fromPosition
     * @param toPosition
     */
    void onItemMove(int fromPosition, int toPosition);
}

2.定义拖拽回调接口

/**
 * 拖动监听
 */
public interface OnStartDragListener {
    /**
     * 开始拖动
     * @param viewHolder
     */
    void onStartDrag(RecyclerView.ViewHolder viewHolder);
}

3.继承ItemTouchHelper.CallBack,并重写方法

public class MySimpleItemTouchHelper extends ItemTouchHelper.Callback{

    private final ItemTouchHelper4Adapter mAdapter;

    public MySimpleItemTouchHelper(ItemTouchHelper4Adapter adapter) {
        mAdapter = adapter;
    }

    @Override
    public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
        // 判断布局类型判断是否支持何种拖动
        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);
        }
    }

    @Override
    public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
        if (viewHolder.getItemViewType() != target.getItemViewType()) {
            return false;
        }

        mAdapter.onItemMove(viewHolder.getAdapterPosition(), target.getAdapterPosition());
        return false;
    }

    @Override
    public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
        //书写对应滑动代码
    }
}

4.自定义Adapter

public class MyRecyclerGridAdapter extends RecyclerView.Adapter<MyRecyclerGridAdapter.ItemViewHolder>
        implements ItemTouchHelper4Adapter {

    private List<String> mItems;

    private final OnStartDragListener mDragStartListener;

    public MyRecyclerGridAdapter(Context context, OnStartDragListener dragStartListener) {
        mDragStartListener = dragStartListener;
        mItems = new ArrayList<String>(){
            {
                add("1");
                add("2");
                add("3");
                add("4");
                add("5");
                add("6");
                add("7");
                add("8");
                add("9");
                add("10");
            }
        };
    }

    @Override
    public ItemViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_image, parent, false);
        ItemViewHolder itemViewHolder = new ItemViewHolder(view);
        return itemViewHolder;
    }

    @Override
    public void onBindViewHolder(ItemViewHolder holder, int position) {

    }

    public void removeItem(int position) {
        mItems.remove(position);
        notifyItemRemoved(position);
        notifyItemRangeChanged(position, mItems.size());
    }

    @Override
    public void onItemMove(int fromPosition, int toPosition) {
        Collections.swap(mItems, fromPosition, toPosition);
        notifyItemMoved(fromPosition, toPosition);
    }

    @Override
    public int getItemCount() {
        return mItems.size();
    }

    /**
     * Simple example of a view holder that implements {@link ItemTouchHelperViewHolder} and has a
     * "handle" view that initiates a drag event when touched.
     */
    public class ItemViewHolder extends RecyclerView.ViewHolder {
        ImageView delImage;

        public ItemViewHolder(View itemView) {
            super(itemView);
            delImage = (ImageView) itemView.findViewById(R.id.delImage);
            delImage.setOnClickListener(deleteListener);
            itemView.setOnTouchListener(onTouchListener);
        }
        View.OnTouchListener onTouchListener = new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                if (MotionEventCompat.getActionMasked(event) == MotionEvent.ACTION_DOWN) {
                    mDragStartListener.onStartDrag(ItemViewHolder.this);
                }
                return false;
            }
        };

        View.OnClickListener deleteListener = new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                removeItem(getAdapterPosition());
            }
        };
    }
}

5.对应的item_image.xml文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/item"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:clickable="true"
    android:focusable="true"
    android:gravity="center"
    >

    <RelativeLayout
        android:layout_width="110dp"
        android:layout_height="110dp">

    <ImageView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentBottom="true"
        android:src="@drawable/bbb"
        />
    <ImageView
        android:id="@+id/delImage"
        android:layout_alignParentRight="true"
        android:layout_width="20dp"
        android:layout_height="20dp"
        android:scaleType="centerInside"
        android:src="@drawable/dialog_close"
        />
    </RelativeLayout>
</RelativeLayout>

6.注意点

  1. 使用点击事件时最好定义在ViewHolder中,不然会发生意想不到的事情…..(如果发现删除或者点击事件不对,不妨去检查一下是否将事件监听放在了onBindViewHolder中)
  2. ViewHolder中通过getAdapterPosition()获取对应数据,进行操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RecyclerViewItemTouchHelper是一个强大的辅助工具类,用于处理RecyclerViewItem的触摸操作和拖拽操作。如果想要让部分Item的位置固定,可以通过以下步骤实现: 1. 首先,创建一个自定义的ItemTouchHelper.Callback类,继承自ItemTouchHelper.Callback。在该类中重写以下几个方法: - getMovementFlags()方法:返回Item拖拽和滑动方向,可以根据具体需求对各个Item设置不同的拖拽和滑动方向。 - onMove()方法:处理Item拖拽操作,可以在此方法中完成Item位置的交换。在交换时,需要判断被拖拽Item是否是固定位置的Item,如果是,则不进行交换操作。 - onSwiped()方法:处理Item的滑动操作,可以在此方法中完成Item的滑动删除操作。同样在滑动删除时,需要判断被滑动的Item是否是固定位置的Item,如果是,则不进行删除操作。 2. 在RecyclerViewAdapter中,重写以下几个方法: - onBindViewHolder()方法:在该方法中为每个Item添加触摸事件的监听器,只有非固定位置的Item才可以进行触摸操作。 3. 在MainActivity或其他适当的地方,创建ItemTouchHelper对象,并将自定义的ItemTouchHelper.Callback类传入。 - ItemTouchHelper itemTouchHelper = new ItemTouchHelper(new CustomItemTouchHelperCallback()); 4. 将ItemTouchHelper对象与RecyclerView进行绑定。 - itemTouchHelper.attachToRecyclerView(recyclerView); 通过以上步骤的实现,可以实现RecyclerView中部分Item固定位置的效果。在进行拖拽或滑动操作时,会自动跳过固定位置的Item,并保持其固定位置不变。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值