From a13b6a311910a8b0b01783fde2a2ce90e7d5fc91 Mon Sep 17 00:00:00 2001 From: luoxwen Date: Wed, 13 Jul 2016 15:10:09 +0800 Subject: [PATCH 1/4] Update README.md about item drag and swipe function --- README-cn.md | 13 +++++++++++++ README.md | 13 +++++++++++++ 2 files changed, 26 insertions(+) diff --git a/README-cn.md b/README-cn.md index c5360b793..4b708a1a1 100644 --- a/README-cn.md +++ b/README-cn.md @@ -223,6 +223,19 @@ OnItemSwipeListener onItemSwipeListener = new OnItemSwipeListener() { public void onItemSwiped(RecyclerView.ViewHolder viewHolder, int pos) {} }; +public class ItemDragAdapter extends BaseItemDraggableAdapter { + public ItemDragAdapter(List data) { + super(R.layout.item_draggable_view, data); + } + + @Override + protected void convert(BaseViewHolder helper, String item) { + helper.setText(R.id.tv, item); + } +} + +mAdapter = new ItemDragAdapter(mData); + ItemDragAndSwipeCallback itemDragAndSwipeCallback = new ItemDragAndSwipeCallback(mAdapter); ItemTouchHelper itemTouchHelper = new ItemTouchHelper(itemDragAndSwipeCallback); itemTouchHelper.attachToRecyclerView(mRecyclerView); diff --git a/README.md b/README.md index f040c80dd..2f64ad97a 100644 --- a/README.md +++ b/README.md @@ -224,6 +224,19 @@ OnItemSwipeListener onItemSwipeListener = new OnItemSwipeListener() { public void onItemSwiped(RecyclerView.ViewHolder viewHolder, int pos) {} }; +public class ItemDragAdapter extends BaseItemDraggableAdapter { + public ItemDragAdapter(List data) { + super(R.layout.item_draggable_view, data); + } + + @Override + protected void convert(BaseViewHolder helper, String item) { + helper.setText(R.id.tv, item); + } +} + +mAdapter = new ItemDragAdapter(mData); + ItemDragAndSwipeCallback itemDragAndSwipeCallback = new ItemDragAndSwipeCallback(mAdapter); ItemTouchHelper itemTouchHelper = new ItemTouchHelper(itemDragAndSwipeCallback); itemTouchHelper.attachToRecyclerView(mRecyclerView); From 2132e2b156d6f0c15411af892a16aeb76b09c8cf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=99=88=E5=AE=87=E6=98=8E?= Date: Wed, 13 Jul 2016 15:47:41 +0800 Subject: [PATCH 2/4] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 2f64ad97a..527130675 100644 --- a/README.md +++ b/README.md @@ -32,7 +32,7 @@ allprojects { Add the dependency ```groovy dependencies { - compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:v1.8.8' + compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:v1.9.0' } ``` From f4086b79e7c45b78b6637062d739bc02991439f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=99=88=E5=AE=87=E6=98=8E?= Date: Wed, 13 Jul 2016 15:49:12 +0800 Subject: [PATCH 3/4] Update README-cn.md --- README-cn.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README-cn.md b/README-cn.md index 4b708a1a1..0b43f5738 100644 --- a/README-cn.md +++ b/README-cn.md @@ -37,7 +37,7 @@ 然后在dependencies添加: ``` dependencies { - compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:v1.8.8' + compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:v1.9.0' } ``` From 0b9fbf343e741f0ce265200c5f683c2021f61ad0 Mon Sep 17 00:00:00 2001 From: luoxwen Date: Thu, 14 Jul 2016 16:12:57 +0800 Subject: [PATCH 4/4] The views create by adapter can not be swiped --- .../ItemDragAndSwipeUseActivity.java | 12 ++++++ .../adapter/base/BaseQuickAdapter.java | 8 ++-- .../callback/ItemDragAndSwipeCallback.java | 39 +++++++++++++++---- 3 files changed, 48 insertions(+), 11 deletions(-) diff --git a/app/src/main/java/com/chad/baserecyclerviewadapterhelper/ItemDragAndSwipeUseActivity.java b/app/src/main/java/com/chad/baserecyclerviewadapterhelper/ItemDragAndSwipeUseActivity.java index 3d0d404d1..28345d36a 100644 --- a/app/src/main/java/com/chad/baserecyclerviewadapterhelper/ItemDragAndSwipeUseActivity.java +++ b/app/src/main/java/com/chad/baserecyclerviewadapterhelper/ItemDragAndSwipeUseActivity.java @@ -6,11 +6,14 @@ import android.graphics.Paint; import android.os.Bundle; import android.support.v4.content.ContextCompat; +import android.support.v4.widget.DrawerLayout; import android.support.v7.widget.CardView; import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.RecyclerView; import android.support.v7.widget.helper.ItemTouchHelper; import android.util.Log; +import android.view.View; +import android.view.ViewGroup; import com.chad.baserecyclerviewadapterhelper.adapter.ItemDragAdapter; import com.chad.library.adapter.base.BaseViewHolder; @@ -107,6 +110,8 @@ public void onItemSwipeMoving(Canvas canvas, RecyclerView.ViewHolder viewHolder, mAdapter.enableDragItem(mItemTouchHelper); mAdapter.setOnItemDragListener(listener); + mAdapter.addHeaderView(getView()); + mAdapter.addFooterView(getView()); mRecyclerView.setAdapter(mAdapter); } @@ -118,4 +123,11 @@ private List generateData(int size) { return data; } + private View getView() { + View view = getLayoutInflater().inflate(R.layout.head_view, null); + view.findViewById(R.id.tv).setVisibility(View.GONE); + view.setLayoutParams(new DrawerLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)); + return view; + } + } diff --git a/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java b/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java index 31535071f..8200e0c88 100755 --- a/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java +++ b/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java @@ -62,10 +62,10 @@ public abstract class BaseQuickAdapter extends RecyclerView.Adapter mData; - protected static final int HEADER_VIEW = 0x00000111; - protected static final int LOADING_VIEW = 0x00000222; - protected static final int FOOTER_VIEW = 0x00000333; - protected static final int EMPTY_VIEW = 0x00000555; + public static final int HEADER_VIEW = 0x00000111; + public static final int LOADING_VIEW = 0x00000222; + public static final int FOOTER_VIEW = 0x00000333; + public static final int EMPTY_VIEW = 0x00000555; private View mLoadingView; @IntDef({ALPHAIN, SCALEIN, SLIDEIN_BOTTOM, SLIDEIN_LEFT, SLIDEIN_RIGHT}) diff --git a/library/src/main/java/com/chad/library/adapter/base/callback/ItemDragAndSwipeCallback.java b/library/src/main/java/com/chad/library/adapter/base/callback/ItemDragAndSwipeCallback.java index dca9156ba..3bb0ab0d5 100644 --- a/library/src/main/java/com/chad/library/adapter/base/callback/ItemDragAndSwipeCallback.java +++ b/library/src/main/java/com/chad/library/adapter/base/callback/ItemDragAndSwipeCallback.java @@ -39,10 +39,12 @@ public boolean isItemViewSwipeEnabled() { @Override public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState) { - if (actionState == ItemTouchHelper.ACTION_STATE_DRAG) { + if (actionState == ItemTouchHelper.ACTION_STATE_DRAG + && !isViewCreateByAdapter(viewHolder)) { mAdapter.onItemDragStart(viewHolder); viewHolder.itemView.setTag(R.id.BaseQuickAdapter_dragging_support, true); - } else if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE) { + } else if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE + && !isViewCreateByAdapter(viewHolder)) { mAdapter.onItemSwipeStart(viewHolder); viewHolder.itemView.setTag(R.id.BaseQuickAdapter_swiping_support, true); } @@ -52,6 +54,9 @@ public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionStat @Override public void clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) { super.clearView(recyclerView, viewHolder); + if (isViewCreateByAdapter(viewHolder)) { + return; + } if (viewHolder.itemView.getTag(R.id.BaseQuickAdapter_dragging_support) != null && (Boolean)viewHolder.itemView.getTag(R.id.BaseQuickAdapter_dragging_support)) { @@ -67,6 +72,10 @@ public void clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHol @Override public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) { + if (isViewCreateByAdapter(viewHolder)) { + return makeMovementFlags(0, 0); + } + return makeMovementFlags(mDragMoveFlags, mSwipeMoveFlags); } @@ -86,7 +95,9 @@ public void onMoved(RecyclerView recyclerView, RecyclerView.ViewHolder source, i @Override public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) { - mAdapter.onItemSwiped(viewHolder); + if (!isViewCreateByAdapter(viewHolder)) { + mAdapter.onItemSwiped(viewHolder); + } } @Override @@ -147,18 +158,22 @@ public void setSwipeMoveFlags(int swipeMoveFlags) { } @Override - public void onChildDrawOver(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) { + 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) { + if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE + && !isViewCreateByAdapter(viewHolder)) { View itemView = viewHolder.itemView; c.save(); if (dX > 0) { - c.clipRect(itemView.getLeft(), itemView.getTop(), itemView.getLeft() + dX, itemView.getBottom()); + c.clipRect(itemView.getLeft(), itemView.getTop(), + itemView.getLeft() + dX, itemView.getBottom()); c.translate(itemView.getLeft(), itemView.getTop()); } else { - c.clipRect(itemView.getRight() + dX, itemView.getTop(), itemView.getRight(), itemView.getBottom()); + c.clipRect(itemView.getRight() + dX, itemView.getTop(), + itemView.getRight(), itemView.getBottom()); c.translate(itemView.getRight() + dX, itemView.getTop()); } @@ -167,4 +182,14 @@ public void onChildDrawOver(Canvas c, RecyclerView recyclerView, RecyclerView.Vi } } + + private boolean isViewCreateByAdapter(RecyclerView.ViewHolder viewHolder) { + int type = viewHolder.getItemViewType(); + if (type == mAdapter.HEADER_VIEW || type == mAdapter.LOADING_VIEW + || type == mAdapter.FOOTER_VIEW || type == mAdapter.EMPTY_VIEW) { + return true; + } + return false; + + } }