Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/loopeer/itemtouchhelper-extension
Extension for itemtouchhelper with swipe settling,recover and no conflict with recyclerview
https://github.com/loopeer/itemtouchhelper-extension
Last synced: 4 days ago
JSON representation
Extension for itemtouchhelper with swipe settling,recover and no conflict with recyclerview
- Host: GitHub
- URL: https://github.com/loopeer/itemtouchhelper-extension
- Owner: loopeer
- Created: 2016-08-25T15:28:14.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-04-26T08:29:28.000Z (over 6 years ago)
- Last Synced: 2025-01-08T11:04:16.666Z (11 days ago)
- Language: Java
- Homepage:
- Size: 643 KB
- Stars: 1,038
- Watchers: 22
- Forks: 145
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-github-android-ui - itemtouchhelper-extension - 添加滑动条目处理 (滑动删除)
README
# itemtouchhelper-extension
This library add something for swipe item settling, recover base on the [Itemtouchhelper](https://developer.android.com/reference/android/support/v7/widget/helper/ItemTouchHelper.html).This used in the repo [code-reader](https://github.com/loopeer/code-reader)
[Download Sample](https://github.com/loopeer/itemtouchhelper-extension/releases/tag/1.0.0)
Screenshot
====
### item swipe with spring![](/screenshot/itemtouch_spring.gif)
### item swipe with no spring
![](/screenshot/itemtouch_nospring.gif)
### item swipe with recycler view width![](/screenshot/itemtouch_recycler_width.gif)
Installation
====
```groovy
dependencies {
compile 'com.loopeer.library:itemtouchhelperextension:1.0.6'
}
```
Usages
====
```java
mCallback = new ItemTouchHelperCallback();
mItemTouchHelper = new ItemTouchHelperExtension(mCallback);
mItemTouchHelper.attachToRecyclerView(mRecyclerView);
```ItemTouchHelperCallback just set as Itemtouchhelper. Set your swipe content view **translationX** by moving in method **onChildDraw**
```java
public class ItemTouchHelperCallback extends ItemTouchHelperExtension.Callback {@Override
public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
return makeMovementFlags(0, ItemTouchHelper.START);
}@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
return false;
}
...@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
MainRecyclerAdapter.ItemBaseViewHolder holder = (MainRecyclerAdapter.ItemBaseViewHolder) viewHolder;
holder.mViewContent.setTranslationX(dX);
}
}
```
At last you can let your **viewholder implements Extension** to set swipe settling width
```java
@Override
public float getActionWidth() {
return mActionContainer.getWidth();
}
```
This will use whole recyclerview width when you do not add the widthAdditional Drag Feature
====
If you want to add drag item feature.You just do **super.onChildDraw** in method onChildDraw of the class **ItemTouchHelperCallback**. Just like bottom:
```java
@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
if (dY != 0 && dX == 0) super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);
...
}
```Click Action Button To Close Opened
====
If you want to close item after click action btn in the swipe item. You show add
```java
mItemTouchHelperExtension.closeOpened();
```License
====
Copyright 2016 LoopeerLicensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.