Compare commits
No commits in common. "master" and "v1.2.0" have entirely different histories.
12
.travis.yml
12
.travis.yml
|
|
@ -1,12 +0,0 @@
|
||||||
language: android
|
|
||||||
android:
|
|
||||||
components:
|
|
||||||
- tools
|
|
||||||
- platform-tools
|
|
||||||
- build-tools-25.0.2
|
|
||||||
- android-25
|
|
||||||
- extra-android-support
|
|
||||||
- extra
|
|
||||||
- extra-android-m2repository
|
|
||||||
script:
|
|
||||||
- ./gradlew assembleDebug
|
|
||||||
|
|
@ -1,9 +1,7 @@
|
||||||
# Android Swipe Layout [](https://travis-ci.org/daimajia/AndroidSwipeLayout)
|
# Android Swipe Layout
|
||||||
|
|
||||||
[](https://gitter.im/daimajia/AndroidSwipeLayout?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
[](https://gitter.im/daimajia/AndroidSwipeLayout?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
||||||
|
|
||||||
[](https://insight.io/github.com/daimajia/AndroidSwipeLayout)
|
|
||||||
|
|
||||||
This is the brother of [AndroidViewHover](https://github.com/daimajia/AndroidViewHover).
|
This is the brother of [AndroidViewHover](https://github.com/daimajia/AndroidViewHover).
|
||||||
|
|
||||||
One year ago, I started to make an app named [EverMemo](https://play.google.com/store/apps/details?id=com.zhan_dui.evermemo) with my good friends. The designer gave me a design picture, the design like this:
|
One year ago, I started to make an app named [EverMemo](https://play.google.com/store/apps/details?id=com.zhan_dui.evermemo) with my good friends. The designer gave me a design picture, the design like this:
|
||||||
|
|
@ -73,8 +71,6 @@ dependencies {
|
||||||
|
|
||||||
### Step 2
|
### Step 2
|
||||||
|
|
||||||
**Make sure to use the internal adapter instead of your own!**
|
|
||||||
|
|
||||||
[Wiki Usage](https://github.com/daimajia/AndroidSwipeLayout/wiki/usage)
|
[Wiki Usage](https://github.com/daimajia/AndroidSwipeLayout/wiki/usage)
|
||||||
|
|
||||||
## Wiki
|
## Wiki
|
||||||
|
|
|
||||||
|
|
@ -3,13 +3,9 @@
|
||||||
buildscript {
|
buildscript {
|
||||||
repositories {
|
repositories {
|
||||||
jcenter()
|
jcenter()
|
||||||
maven {
|
|
||||||
url "https://jitpack.io"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'com.android.tools.build:gradle:2.3.0'
|
classpath 'com.android.tools.build:gradle:1.0.0'
|
||||||
classpath 'com.github.dcendents:android-maven-plugin:1.2'
|
|
||||||
|
|
||||||
// NOTE: Do not place your application dependencies here; they belong
|
// NOTE: Do not place your application dependencies here; they belong
|
||||||
// in the individual module build.gradle files
|
// in the individual module build.gradle files
|
||||||
|
|
@ -19,8 +15,5 @@ buildscript {
|
||||||
allprojects {
|
allprojects {
|
||||||
repositories {
|
repositories {
|
||||||
jcenter()
|
jcenter()
|
||||||
maven {
|
|
||||||
url "https://jitpack.io"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -26,7 +26,7 @@ android {
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile project(":library")
|
compile project(":library")
|
||||||
compile 'com.android.support:recyclerview-v7:25.1.1'
|
compile 'com.android.support:recyclerview-v7:21.0.0'
|
||||||
compile 'com.daimajia.easing:library:1.0.0@aar'
|
compile 'com.daimajia.easing:library:1.0.0@aar'
|
||||||
compile 'com.daimajia.androidanimations:library:1.1.2@aar'
|
compile 'com.daimajia.androidanimations:library:1.1.2@aar'
|
||||||
compile 'com.nineoldandroids:library:2.4.0'
|
compile 'com.nineoldandroids:library:2.4.0'
|
||||||
|
|
|
||||||
|
|
@ -15,6 +15,7 @@ import com.daimajia.androidanimations.library.YoYo;
|
||||||
import com.daimajia.swipe.SimpleSwipeListener;
|
import com.daimajia.swipe.SimpleSwipeListener;
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
import com.daimajia.swipe.adapters.RecyclerSwipeAdapter;
|
import com.daimajia.swipe.adapters.RecyclerSwipeAdapter;
|
||||||
|
import com.daimajia.swipe.implments.SwipeItemRecyclerMangerImpl;
|
||||||
import com.daimajia.swipedemo.R;
|
import com.daimajia.swipedemo.R;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
@ -89,7 +90,7 @@ public class RecyclerViewAdapter extends RecyclerSwipeAdapter<RecyclerViewAdapte
|
||||||
});
|
});
|
||||||
viewHolder.textViewPos.setText((position + 1) + ".");
|
viewHolder.textViewPos.setText((position + 1) + ".");
|
||||||
viewHolder.textViewData.setText(item);
|
viewHolder.textViewData.setText(item);
|
||||||
mItemManger.bind(viewHolder.itemView, position);
|
mItemManger.bindView(viewHolder.itemView, position);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
||||||
|
|
@ -37,9 +37,4 @@ public class RecyclerItemClickListener implements RecyclerView.OnItemTouchListen
|
||||||
@Override
|
@Override
|
||||||
public void onTouchEvent(RecyclerView view, MotionEvent motionEvent) {
|
public void onTouchEvent(RecyclerView view, MotionEvent motionEvent) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onRequestDisallowInterceptTouchEvent(boolean disallowIntercept) {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@ VERSION_NAME=1.2.0
|
||||||
VERSION_CODE=22
|
VERSION_CODE=22
|
||||||
GROUP=com.daimajia.swipelayout
|
GROUP=com.daimajia.swipelayout
|
||||||
|
|
||||||
ANDROID_BUILD_MIN_SDK_VERSION=9
|
ANDROID_BUILD_MIN_SDK_VERSION=8
|
||||||
ANDROID_BUILD_TARGET_SDK_VERSION=25
|
ANDROID_BUILD_TARGET_SDK_VERSION=21
|
||||||
ANDROID_BUILD_SDK_VERSION=25
|
ANDROID_BUILD_SDK_VERSION=21
|
||||||
ANDROID_BUILD_TOOLS_VERSION=25.0.2
|
ANDROID_BUILD_TOOLS_VERSION=21.0.0
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
#Thu Mar 09 16:07:03 CST 2017
|
#Wed Apr 10 15:27:10 PDT 2013
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip
|
distributionUrl=http\://services.gradle.org/distributions/gradle-2.2.1-all.zip
|
||||||
|
|
@ -5,22 +5,13 @@ android {
|
||||||
buildToolsVersion project.ANDROID_BUILD_TOOLS_VERSION
|
buildToolsVersion project.ANDROID_BUILD_TOOLS_VERSION
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 9
|
minSdkVersion 8
|
||||||
targetSdkVersion Integer.parseInt(project.ANDROID_BUILD_TARGET_SDK_VERSION)
|
targetSdkVersion Integer.parseInt(project.ANDROID_BUILD_TARGET_SDK_VERSION)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile 'com.android.support:recyclerview-v7:25.2.0'
|
compile 'com.android.support:recyclerview-v7:21.0.0'
|
||||||
compile 'com.android.support:support-v4:25.2.0'
|
compile 'com.android.support:support-v4:21.0.3'
|
||||||
}
|
}
|
||||||
apply from: './gradle-mvn-push.gradle'
|
apply from: './gradle-mvn-push.gradle'
|
||||||
|
|
||||||
// build a jar with source files
|
|
||||||
task sourcesJar(type: Jar) {
|
|
||||||
from android.sourceSets.main.java.srcDirs
|
|
||||||
classifier = 'sources'
|
|
||||||
}
|
|
||||||
artifacts {
|
|
||||||
archives sourcesJar
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,2 @@
|
||||||
<manifest package="com.daimajia.swipe">
|
|
||||||
<application />
|
<manifest package="com.daimajia.swipe"/>
|
||||||
</manifest>
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@ package com.daimajia.swipe;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.res.TypedArray;
|
import android.content.res.TypedArray;
|
||||||
import android.graphics.Rect;
|
import android.graphics.Rect;
|
||||||
|
import android.support.annotation.Nullable;
|
||||||
import android.support.v4.view.GravityCompat;
|
import android.support.v4.view.GravityCompat;
|
||||||
import android.support.v4.view.ViewCompat;
|
import android.support.v4.view.ViewCompat;
|
||||||
import android.support.v4.widget.ViewDragHelper;
|
import android.support.v4.widget.ViewDragHelper;
|
||||||
|
|
@ -42,33 +43,30 @@ public class SwipeLayout extends FrameLayout {
|
||||||
private ViewDragHelper mDragHelper;
|
private ViewDragHelper mDragHelper;
|
||||||
|
|
||||||
private int mDragDistance = 0;
|
private int mDragDistance = 0;
|
||||||
private LinkedHashMap<DragEdge, View> mDragEdges = new LinkedHashMap<>();
|
private LinkedHashMap<DragEdge, View> mDragEdges = new LinkedHashMap<DragEdge, View>();
|
||||||
private ShowMode mShowMode;
|
private ShowMode mShowMode;
|
||||||
|
|
||||||
private float[] mEdgeSwipesOffset = new float[4];
|
private float[] mEdgeSwipesOffset = new float[4];
|
||||||
|
|
||||||
private List<SwipeListener> mSwipeListeners = new ArrayList<>();
|
private List<SwipeListener> mSwipeListeners = new ArrayList<SwipeListener>();
|
||||||
private List<SwipeDenier> mSwipeDeniers = new ArrayList<>();
|
private List<SwipeDenier> mSwipeDeniers = new ArrayList<SwipeDenier>();
|
||||||
private Map<View, ArrayList<OnRevealListener>> mRevealListeners = new HashMap<>();
|
private Map<View, ArrayList<OnRevealListener>> mRevealListeners = new HashMap<View, ArrayList<OnRevealListener>>();
|
||||||
private Map<View, Boolean> mShowEntirely = new HashMap<>();
|
private Map<View, Boolean> mShowEntirely = new HashMap<View, Boolean>();
|
||||||
private Map<View, Rect> mViewBoundCache = new HashMap<>();//save all children's bound, restore in onLayout
|
|
||||||
|
|
||||||
private DoubleClickListener mDoubleClickListener;
|
private DoubleClickListener mDoubleClickListener;
|
||||||
|
|
||||||
private boolean mSwipeEnabled = true;
|
private boolean mSwipeEnabled = true;
|
||||||
private boolean[] mSwipesEnabled = new boolean[]{true, true, true, true};
|
private boolean[] mSwipesEnabled = new boolean[]{true, true, true, true};
|
||||||
private boolean mClickToClose = false;
|
private boolean mClickToClose = false;
|
||||||
private float mWillOpenPercentAfterOpen = 0.75f;
|
|
||||||
private float mWillOpenPercentAfterClose = 0.25f;
|
|
||||||
|
|
||||||
public enum DragEdge {
|
public static enum DragEdge {
|
||||||
Left,
|
Left,
|
||||||
Top,
|
Top,
|
||||||
Right,
|
Right,
|
||||||
Bottom
|
Bottom
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ShowMode {
|
public static enum ShowMode {
|
||||||
LayDown,
|
LayDown,
|
||||||
PullOut
|
PullOut
|
||||||
}
|
}
|
||||||
|
|
@ -113,17 +111,17 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface SwipeListener {
|
public interface SwipeListener {
|
||||||
void onStartOpen(SwipeLayout layout);
|
public void onStartOpen(SwipeLayout layout);
|
||||||
|
|
||||||
void onOpen(SwipeLayout layout);
|
public void onOpen(SwipeLayout layout);
|
||||||
|
|
||||||
void onStartClose(SwipeLayout layout);
|
public void onStartClose(SwipeLayout layout);
|
||||||
|
|
||||||
void onClose(SwipeLayout layout);
|
public void onClose(SwipeLayout layout);
|
||||||
|
|
||||||
void onUpdate(SwipeLayout layout, int leftOffset, int topOffset);
|
public void onUpdate(SwipeLayout layout, int leftOffset, int topOffset);
|
||||||
|
|
||||||
void onHandRelease(SwipeLayout layout, float xvel, float yvel);
|
public void onHandRelease(SwipeLayout layout, float xvel, float yvel);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addSwipeListener(SwipeListener l) {
|
public void addSwipeListener(SwipeListener l) {
|
||||||
|
|
@ -134,11 +132,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
mSwipeListeners.remove(l);
|
mSwipeListeners.remove(l);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removeAllSwipeListener() {
|
public static interface SwipeDenier {
|
||||||
mSwipeListeners.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
public interface SwipeDenier {
|
|
||||||
/*
|
/*
|
||||||
* Called in onInterceptTouchEvent Determines if this swipe event should
|
* Called in onInterceptTouchEvent Determines if this swipe event should
|
||||||
* be denied Implement this interface if you are using views with swipe
|
* be denied Implement this interface if you are using views with swipe
|
||||||
|
|
@ -146,7 +140,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
*
|
*
|
||||||
* @return true deny false allow
|
* @return true deny false allow
|
||||||
*/
|
*/
|
||||||
boolean shouldDenySwipe(MotionEvent ev);
|
public boolean shouldDenySwipe(MotionEvent ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addSwipeDenier(SwipeDenier denier) {
|
public void addSwipeDenier(SwipeDenier denier) {
|
||||||
|
|
@ -162,7 +156,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface OnRevealListener {
|
public interface OnRevealListener {
|
||||||
void onReveal(View child, DragEdge edge, float fraction, int distance);
|
public void onReveal(View child, DragEdge edge, float fraction, int distance);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -332,14 +326,13 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean isCloseBeforeDrag = true;
|
boolean isCloseBeforeDrag = true;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onViewReleased(View releasedChild, float xvel, float yvel) {
|
public void onViewReleased(View releasedChild, float xvel, float yvel) {
|
||||||
super.onViewReleased(releasedChild, xvel, yvel);
|
super.onViewReleased(releasedChild, xvel, yvel);
|
||||||
processHandRelease(xvel, yvel, isCloseBeforeDrag);
|
|
||||||
for (SwipeListener l : mSwipeListeners){
|
for (SwipeListener l : mSwipeListeners){
|
||||||
l.onHandRelease(SwipeLayout.this, xvel, yvel);
|
l.onHandRelease(SwipeLayout.this, xvel, yvel);
|
||||||
}
|
}
|
||||||
|
processHandRelease(xvel, yvel, isCloseBeforeDrag);
|
||||||
|
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
|
@ -394,35 +387,9 @@ public class SwipeLayout extends FrameLayout {
|
||||||
dispatchSwipeEvent(evLeft, evTop, dx, dy);
|
dispatchSwipeEvent(evLeft, evTop, dx, dy);
|
||||||
|
|
||||||
invalidate();
|
invalidate();
|
||||||
|
|
||||||
captureChildrenBound();
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* save children's bounds, so they can restore the bound in {@link #onLayout(boolean, int, int, int, int)}
|
|
||||||
*/
|
|
||||||
private void captureChildrenBound() {
|
|
||||||
View currentBottomView = getCurrentBottomView();
|
|
||||||
if (getOpenStatus() == Status.Close) {
|
|
||||||
mViewBoundCache.remove(currentBottomView);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
View[] views = new View[]{getSurfaceView(), currentBottomView};
|
|
||||||
for (View child : views) {
|
|
||||||
Rect rect = mViewBoundCache.get(child);
|
|
||||||
if (rect == null) {
|
|
||||||
rect = new Rect();
|
|
||||||
mViewBoundCache.put(child, rect);
|
|
||||||
}
|
|
||||||
rect.left = child.getLeft();
|
|
||||||
rect.top = child.getTop();
|
|
||||||
rect.right = child.getRight();
|
|
||||||
rect.bottom = child.getBottom();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the dispatchRevealEvent method may not always get accurate position, it
|
* the dispatchRevealEvent method may not always get accurate position, it
|
||||||
* makes the view may not always get the event when the view is totally
|
* makes the view may not always get the event when the view is totally
|
||||||
|
|
@ -675,7 +642,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
* to support it from API 8.
|
* to support it from API 8.
|
||||||
*/
|
*/
|
||||||
public interface OnLayout {
|
public interface OnLayout {
|
||||||
void onLayout(SwipeLayout v);
|
public void onLayout(SwipeLayout v);
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<OnLayout> mOnLayoutListeners;
|
private List<OnLayout> mOnLayoutListeners;
|
||||||
|
|
@ -688,32 +655,10 @@ public class SwipeLayout extends FrameLayout {
|
||||||
public void removeOnLayoutListener(OnLayout l) {
|
public void removeOnLayoutListener(OnLayout l) {
|
||||||
if (mOnLayoutListeners != null) mOnLayoutListeners.remove(l);
|
if (mOnLayoutListeners != null) mOnLayoutListeners.remove(l);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearDragEdge() {
|
|
||||||
mDragEdges.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDrag(DragEdge dragEdge, int childId) {
|
|
||||||
clearDragEdge();
|
|
||||||
addDrag(dragEdge, childId);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDrag(DragEdge dragEdge, View child) {
|
|
||||||
clearDragEdge();
|
|
||||||
addDrag(dragEdge, child);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addDrag(DragEdge dragEdge, int childId) {
|
|
||||||
addDrag(dragEdge, findViewById(childId), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addDrag(DragEdge dragEdge, View child){
|
public void addDrag(DragEdge dragEdge, View child){
|
||||||
addDrag(dragEdge, child, null);
|
addDrag(dragEdge, child, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addDrag(DragEdge dragEdge, View child, ViewGroup.LayoutParams params){
|
public void addDrag(DragEdge dragEdge, View child, ViewGroup.LayoutParams params){
|
||||||
if (child == null) return;
|
|
||||||
|
|
||||||
if(params==null){
|
if(params==null){
|
||||||
params = generateDefaultLayoutParams();
|
params = generateDefaultLayoutParams();
|
||||||
}
|
}
|
||||||
|
|
@ -722,28 +667,18 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
int gravity = -1;
|
int gravity = -1;
|
||||||
switch (dragEdge){
|
switch (dragEdge){
|
||||||
case Left:
|
case Left:gravity = Gravity.LEFT;break;
|
||||||
gravity = Gravity.LEFT;
|
case Right:gravity = Gravity.RIGHT;break;
|
||||||
break;
|
case Top:gravity = Gravity.TOP;break;
|
||||||
case Right:
|
case Bottom:gravity = Gravity.BOTTOM;break;
|
||||||
gravity = Gravity.RIGHT;
|
|
||||||
break;
|
|
||||||
case Top:
|
|
||||||
gravity = Gravity.TOP;
|
|
||||||
break;
|
|
||||||
case Bottom:
|
|
||||||
gravity = Gravity.BOTTOM;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
if(params instanceof FrameLayout.LayoutParams){
|
if(params instanceof FrameLayout.LayoutParams){
|
||||||
((LayoutParams) params).gravity = gravity;
|
((LayoutParams) params).gravity = gravity;
|
||||||
}
|
}
|
||||||
addView(child, 0, params);
|
addView(child, 0, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void addView(View child, int index, ViewGroup.LayoutParams params) {
|
public void addView(View child, int index, ViewGroup.LayoutParams params) {
|
||||||
if (child == null) return;
|
|
||||||
int gravity = Gravity.NO_GRAVITY;
|
int gravity = Gravity.NO_GRAVITY;
|
||||||
try {
|
try {
|
||||||
gravity = (Integer) params.getClass().getField("gravity").get(params);
|
gravity = (Integer) params.getClass().getField("gravity").get(params);
|
||||||
|
|
@ -775,7 +710,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (child.getParent() == this) {
|
if(child==null || child.getParent() == this){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
super.addView(child, index, params);
|
super.addView(child, index, params);
|
||||||
|
|
@ -791,41 +726,34 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
void layoutPullOut() {
|
void layoutPullOut() {
|
||||||
|
Rect rect = computeSurfaceLayoutArea(false);
|
||||||
View surfaceView = getSurfaceView();
|
View surfaceView = getSurfaceView();
|
||||||
Rect surfaceRect = mViewBoundCache.get(surfaceView);
|
|
||||||
if (surfaceRect == null) surfaceRect = computeSurfaceLayoutArea(false);
|
|
||||||
if(surfaceView!=null){
|
if(surfaceView!=null){
|
||||||
surfaceView.layout(surfaceRect.left, surfaceRect.top, surfaceRect.right, surfaceRect.bottom);
|
surfaceView.layout(rect.left, rect.top, rect.right, rect.bottom);
|
||||||
bringChildToFront(surfaceView);
|
bringChildToFront(surfaceView);
|
||||||
}
|
}
|
||||||
|
rect = computeBottomLayoutAreaViaSurface(ShowMode.PullOut, rect);
|
||||||
View currentBottomView = getCurrentBottomView();
|
View currentBottomView = getCurrentBottomView();
|
||||||
Rect bottomViewRect = mViewBoundCache.get(currentBottomView);
|
|
||||||
if (bottomViewRect == null)
|
|
||||||
bottomViewRect = computeBottomLayoutAreaViaSurface(ShowMode.PullOut, surfaceRect);
|
|
||||||
if(currentBottomView!=null){
|
if(currentBottomView!=null){
|
||||||
currentBottomView.layout(bottomViewRect.left, bottomViewRect.top, bottomViewRect.right, bottomViewRect.bottom);
|
currentBottomView.layout(rect.left, rect.top, rect.right, rect.bottom);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void layoutLayDown() {
|
void layoutLayDown() {
|
||||||
|
Rect rect = computeSurfaceLayoutArea(false);
|
||||||
View surfaceView = getSurfaceView();
|
View surfaceView = getSurfaceView();
|
||||||
Rect surfaceRect = mViewBoundCache.get(surfaceView);
|
|
||||||
if (surfaceRect == null) surfaceRect = computeSurfaceLayoutArea(false);
|
|
||||||
if(surfaceView!=null){
|
if(surfaceView!=null){
|
||||||
surfaceView.layout(surfaceRect.left, surfaceRect.top, surfaceRect.right, surfaceRect.bottom);
|
surfaceView.layout(rect.left, rect.top, rect.right, rect.bottom);
|
||||||
bringChildToFront(surfaceView);
|
bringChildToFront(surfaceView);
|
||||||
}
|
}
|
||||||
|
rect = computeBottomLayoutAreaViaSurface(ShowMode.LayDown, rect);
|
||||||
View currentBottomView = getCurrentBottomView();
|
View currentBottomView = getCurrentBottomView();
|
||||||
Rect bottomViewRect = mViewBoundCache.get(currentBottomView);
|
|
||||||
if (bottomViewRect == null)
|
|
||||||
bottomViewRect = computeBottomLayoutAreaViaSurface(ShowMode.LayDown, surfaceRect);
|
|
||||||
if(currentBottomView!=null){
|
if(currentBottomView!=null){
|
||||||
currentBottomView.layout(bottomViewRect.left, bottomViewRect.top, bottomViewRect.right, bottomViewRect.bottom);
|
currentBottomView.layout(rect.left, rect.top, rect.right, rect.bottom);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean mIsBeingDragged;
|
private boolean mIsBeingDragged;
|
||||||
|
|
||||||
private void checkCanDrag(MotionEvent ev){
|
private void checkCanDrag(MotionEvent ev){
|
||||||
if(mIsBeingDragged) return;
|
if(mIsBeingDragged) return;
|
||||||
if(getOpenStatus()==Status.Middle){
|
if(getOpenStatus()==Status.Middle){
|
||||||
|
|
@ -898,7 +826,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
mIsBeingDragged = !doNothing;
|
mIsBeingDragged = !doNothing;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onInterceptTouchEvent(MotionEvent ev) {
|
public boolean onInterceptTouchEvent(MotionEvent ev) {
|
||||||
if (!isSwipeEnabled()) {
|
if (!isSwipeEnabled()) {
|
||||||
|
|
@ -988,7 +915,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
|
|
||||||
return super.onTouchEvent(event) || mIsBeingDragged || action == MotionEvent.ACTION_DOWN;
|
return super.onTouchEvent(event) || mIsBeingDragged || action == MotionEvent.ACTION_DOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isClickToClose() {
|
public boolean isClickToClose() {
|
||||||
return mClickToClose;
|
return mClickToClose;
|
||||||
}
|
}
|
||||||
|
|
@ -1044,47 +970,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
public void setBottomSwipeEnabled(boolean bottomSwipeEnabled) {
|
public void setBottomSwipeEnabled(boolean bottomSwipeEnabled) {
|
||||||
this.mSwipesEnabled[DragEdge.Bottom.ordinal()] = bottomSwipeEnabled;
|
this.mSwipesEnabled[DragEdge.Bottom.ordinal()] = bottomSwipeEnabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
/***
|
|
||||||
* Returns the percentage of revealing at which the view below should the view finish opening
|
|
||||||
* if it was already open before dragging
|
|
||||||
*
|
|
||||||
* @returns The percentage of view revealed to trigger, default value is 0.25
|
|
||||||
*/
|
|
||||||
public float getWillOpenPercentAfterOpen() {
|
|
||||||
return mWillOpenPercentAfterOpen;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***
|
|
||||||
* Allows to stablish at what percentage of revealing the view below should the view finish opening
|
|
||||||
* if it was already open before dragging
|
|
||||||
*
|
|
||||||
* @param willOpenPercentAfterOpen The percentage of view revealed to trigger, default value is 0.25
|
|
||||||
*/
|
|
||||||
public void setWillOpenPercentAfterOpen(float willOpenPercentAfterOpen) {
|
|
||||||
this.mWillOpenPercentAfterOpen = willOpenPercentAfterOpen;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***
|
|
||||||
* Returns the percentage of revealing at which the view below should the view finish opening
|
|
||||||
* if it was already closed before dragging
|
|
||||||
*
|
|
||||||
* @returns The percentage of view revealed to trigger, default value is 0.25
|
|
||||||
*/
|
|
||||||
public float getWillOpenPercentAfterClose() {
|
|
||||||
return mWillOpenPercentAfterClose;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***
|
|
||||||
* Allows to stablish at what percentage of revealing the view below should the view finish opening
|
|
||||||
* if it was already closed before dragging
|
|
||||||
*
|
|
||||||
* @param willOpenPercentAfterClose The percentage of view revealed to trigger, default value is 0.75
|
|
||||||
*/
|
|
||||||
public void setWillOpenPercentAfterClose(float willOpenPercentAfterClose) {
|
|
||||||
this.mWillOpenPercentAfterClose = willOpenPercentAfterClose;
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean insideAdapterView() {
|
private boolean insideAdapterView() {
|
||||||
return getAdapterView() != null;
|
return getAdapterView() != null;
|
||||||
}
|
}
|
||||||
|
|
@ -1109,7 +994,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean performAdapterViewItemLongClick() {
|
private boolean performAdapterViewItemLongClick() {
|
||||||
if(getOpenStatus()!= Status.Close) return false;
|
if(getOpenStatus()!= Status.Close) return false;
|
||||||
ViewParent t = getParent();
|
ViewParent t = getParent();
|
||||||
|
|
@ -1138,7 +1022,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onAttachedToWindow() {
|
protected void onAttachedToWindow() {
|
||||||
super.onAttachedToWindow();
|
super.onAttachedToWindow();
|
||||||
|
|
@ -1162,17 +1045,13 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
OnClickListener clickListener;
|
OnClickListener clickListener;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setOnClickListener(OnClickListener l) {
|
public void setOnClickListener(OnClickListener l) {
|
||||||
super.setOnClickListener(l);
|
super.setOnClickListener(l);
|
||||||
clickListener = l;
|
clickListener = l;
|
||||||
}
|
}
|
||||||
|
|
||||||
OnLongClickListener longClickListener;
|
OnLongClickListener longClickListener;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setOnLongClickListener(OnLongClickListener l) {
|
public void setOnLongClickListener(OnLongClickListener l) {
|
||||||
super.setOnLongClickListener(l);
|
super.setOnLongClickListener(l);
|
||||||
|
|
@ -1180,7 +1059,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
private Rect hitSurfaceRect;
|
private Rect hitSurfaceRect;
|
||||||
|
|
||||||
private boolean isTouchOnSurface(MotionEvent ev){
|
private boolean isTouchOnSurface(MotionEvent ev){
|
||||||
View surfaceView = getSurfaceView();
|
View surfaceView = getSurfaceView();
|
||||||
if(surfaceView==null){
|
if(surfaceView==null){
|
||||||
|
|
@ -1192,7 +1070,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
surfaceView.getHitRect(hitSurfaceRect);
|
surfaceView.getHitRect(hitSurfaceRect);
|
||||||
return hitSurfaceRect.contains((int) ev.getX(), (int) ev.getY());
|
return hitSurfaceRect.contains((int) ev.getX(), (int) ev.getY());
|
||||||
}
|
}
|
||||||
|
|
||||||
private GestureDetector gestureDetector = new GestureDetector(getContext(), new SwipeDetector());
|
private GestureDetector gestureDetector = new GestureDetector(getContext(), new SwipeDetector());
|
||||||
|
|
||||||
class SwipeDetector extends GestureDetector.SimpleOnGestureListener {
|
class SwipeDetector extends GestureDetector.SimpleOnGestureListener {
|
||||||
|
|
@ -1203,7 +1080,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
return super.onSingleTapUp(e);
|
return super.onSingleTapUp(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onDoubleTap(MotionEvent e) {
|
public boolean onDoubleTap(MotionEvent e) {
|
||||||
if (mDoubleClickListener != null) {
|
if (mDoubleClickListener != null) {
|
||||||
|
|
@ -1258,17 +1134,14 @@ public class SwipeLayout extends FrameLayout {
|
||||||
return mShowMode;
|
return mShowMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**return null if there is no surface view(no children) */
|
||||||
* return null if there is no surface view(no children)
|
|
||||||
*/
|
|
||||||
public View getSurfaceView() {
|
public View getSurfaceView() {
|
||||||
if(getChildCount()==0) return null;
|
if(getChildCount()==0) return null;
|
||||||
return getChildAt(getChildCount() - 1);
|
return getChildAt(getChildCount() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**return null if there is no bottom view */
|
||||||
* return null if there is no bottom view
|
@Nullable
|
||||||
*/
|
|
||||||
public View getCurrentBottomView(){
|
public View getCurrentBottomView(){
|
||||||
List<View> bottoms = getBottomViews();
|
List<View> bottoms = getBottomViews();
|
||||||
if(mCurrentDragEdge.ordinal() < bottoms.size()){
|
if(mCurrentDragEdge.ordinal() < bottoms.size()){
|
||||||
|
|
@ -1276,7 +1149,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return all bottomViews: left, top, right, bottom (may null if the edge is not set)
|
* @return all bottomViews: left, top, right, bottom (may null if the edge is not set)
|
||||||
*/
|
*/
|
||||||
|
|
@ -1331,7 +1203,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
if(currentDragEdge == null || surfaceView == null){
|
if(currentDragEdge == null || surfaceView == null){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
float willOpenPercent = (isCloseBeforeDragged ? mWillOpenPercentAfterClose : mWillOpenPercentAfterOpen);
|
float willOpenPercent = (isCloseBeforeDragged ? .25f : .75f);
|
||||||
if(currentDragEdge == DragEdge.Left){
|
if(currentDragEdge == DragEdge.Left){
|
||||||
if(xvel > minVelocity) open();
|
if(xvel > minVelocity) open();
|
||||||
else if(xvel < -minVelocity) close();
|
else if(xvel < -minVelocity) close();
|
||||||
|
|
@ -1475,7 +1347,6 @@ public class SwipeLayout extends FrameLayout {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* a helper function to compute the Rect area that surface will hold in.
|
* a helper function to compute the Rect area that surface will hold in.
|
||||||
*
|
|
||||||
* @param open open status or close status.
|
* @param open open status or close status.
|
||||||
*/
|
*/
|
||||||
private Rect computeSurfaceLayoutArea(boolean open) {
|
private Rect computeSurfaceLayoutArea(boolean open) {
|
||||||
|
|
@ -1550,7 +1421,7 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface DoubleClickListener {
|
public interface DoubleClickListener {
|
||||||
void onDoubleClick(SwipeLayout layout, boolean surface);
|
public void onDoubleClick(SwipeLayout layout, boolean surface);
|
||||||
}
|
}
|
||||||
|
|
||||||
private int dp2px(float dp) {
|
private int dp2px(float dp) {
|
||||||
|
|
@ -1558,44 +1429,35 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**Deprecated, use {@link #addDrag(DragEdge, View)} */
|
||||||
* Deprecated, use {@link #setDrag(DragEdge, View)}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public void setDragEdge(DragEdge dragEdge) {
|
public void setDragEdge(DragEdge dragEdge) {
|
||||||
clearDragEdge();
|
|
||||||
if(getChildCount() >= 2){
|
if(getChildCount() >= 2){
|
||||||
mDragEdges.put(dragEdge, getChildAt(getChildCount()-2));
|
mDragEdges.put(dragEdge, getChildAt(getChildCount()-2));
|
||||||
}
|
}
|
||||||
setCurrentDragEdge(dragEdge);
|
setCurrentDragEdge(dragEdge);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onViewRemoved(View child) {
|
protected void onViewRemoved(View child) {
|
||||||
for(Map.Entry<DragEdge, View> entry : new HashMap<DragEdge, View>(mDragEdges).entrySet()){
|
for(Map.Entry<DragEdge, View> entry : new HashMap<DragEdge, View>(mDragEdges).entrySet()){
|
||||||
if(entry.getValue() == child){
|
if(entry.getValue() == child){
|
||||||
mDragEdges.remove(entry.getKey());
|
mDragEdges.remove(entry.getKey());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<DragEdge, View> getDragEdgeMap(){
|
public Map<DragEdge, View> getDragEdgeMap(){
|
||||||
return mDragEdges;
|
return mDragEdges;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**Deprecated, use {@link #getDragEdgeMap()} */
|
||||||
* Deprecated, use {@link #getDragEdgeMap()}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public List<DragEdge> getDragEdges() {
|
public List<DragEdge> getDragEdges() {
|
||||||
return new ArrayList<DragEdge>(mDragEdges.keySet());
|
return new ArrayList<DragEdge>(mDragEdges.keySet());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**Deprecated, use {@link #addDrag(DragEdge, View)} */
|
||||||
* Deprecated, use {@link #setDrag(DragEdge, View)}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public void setDragEdges(List<DragEdge> dragEdges) {
|
public void setDragEdges(List<DragEdge> dragEdges) {
|
||||||
clearDragEdge();
|
|
||||||
for (int i = 0, size = Math.min(dragEdges.size(), getChildCount() - 1); i < size; i++) {
|
for (int i = 0, size = Math.min(dragEdges.size(), getChildCount() - 1); i < size; i++) {
|
||||||
DragEdge dragEdge = dragEdges.get(i);
|
DragEdge dragEdge = dragEdges.get(i);
|
||||||
mDragEdges.put(dragEdge, getChildAt(i));
|
mDragEdges.put(dragEdge, getChildAt(i));
|
||||||
|
|
@ -1607,15 +1469,11 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**Deprecated, use {@link #addDrag(DragEdge, View)} */
|
||||||
* Deprecated, use {@link #addDrag(DragEdge, View)}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public void setDragEdges(DragEdge... mDragEdges) {
|
public void setDragEdges(DragEdge... mDragEdges) {
|
||||||
clearDragEdge();
|
|
||||||
setDragEdges(Arrays.asList(mDragEdges));
|
setDragEdges(Arrays.asList(mDragEdges));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deprecated, use {@link #addDrag(DragEdge, View)}
|
* Deprecated, use {@link #addDrag(DragEdge, View)}
|
||||||
* When using multiple drag edges it's a good idea to pass the ids of the views that
|
* When using multiple drag edges it's a good idea to pass the ids of the views that
|
||||||
|
|
@ -1635,25 +1493,24 @@ public class SwipeLayout extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setCurrentDragEdge(DragEdge dragEdge){
|
private void setCurrentDragEdge(DragEdge dragEdge){
|
||||||
|
if(mCurrentDragEdge != dragEdge){
|
||||||
mCurrentDragEdge = dragEdge;
|
mCurrentDragEdge = dragEdge;
|
||||||
updateBottomViews();
|
updateBottomViews();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void updateBottomViews() {
|
private void updateBottomViews() {
|
||||||
View currentBottomView = getCurrentBottomView();
|
View currentBottomView = getCurrentBottomView();
|
||||||
if(currentBottomView!=null){
|
if(currentBottomView!=null){
|
||||||
if (mCurrentDragEdge == DragEdge.Left || mCurrentDragEdge == DragEdge.Right) {
|
if (mCurrentDragEdge == DragEdge.Left || mCurrentDragEdge == DragEdge.Right) {
|
||||||
mDragDistance = currentBottomView.getMeasuredWidth() - dp2px(getCurrentOffset());
|
mDragDistance = currentBottomView.getMeasuredWidth() - dp2px(getCurrentOffset());
|
||||||
} else {
|
|
||||||
mDragDistance = currentBottomView.getMeasuredHeight() - dp2px(getCurrentOffset());
|
|
||||||
}
|
}
|
||||||
|
else mDragDistance = currentBottomView.getMeasuredHeight() - dp2px(getCurrentOffset());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mShowMode == ShowMode.PullOut) {
|
if (mShowMode == ShowMode.PullOut)
|
||||||
layoutPullOut();
|
layoutPullOut();
|
||||||
} else if (mShowMode == ShowMode.LayDown) {
|
else if (mShowMode == ShowMode.LayDown) layoutLayDown();
|
||||||
layoutLayDown();
|
|
||||||
}
|
|
||||||
|
|
||||||
safeBottomView();
|
safeBottomView();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@ import android.view.ViewGroup;
|
||||||
import android.widget.ArrayAdapter;
|
import android.widget.ArrayAdapter;
|
||||||
|
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
|
import com.daimajia.swipe.implments.SwipeItemAdapterMangerImpl;
|
||||||
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
|
|
@ -15,7 +16,7 @@ import java.util.List;
|
||||||
|
|
||||||
public abstract class ArraySwipeAdapter<T> extends ArrayAdapter implements SwipeItemMangerInterface,SwipeAdapterInterface {
|
public abstract class ArraySwipeAdapter<T> extends ArrayAdapter implements SwipeItemMangerInterface,SwipeAdapterInterface {
|
||||||
|
|
||||||
private SwipeItemMangerImpl mItemManger = new SwipeItemMangerImpl(this);
|
private SwipeItemAdapterMangerImpl mItemManger = new SwipeItemAdapterMangerImpl(this);
|
||||||
{}
|
{}
|
||||||
public ArraySwipeAdapter(Context context, int resource) {
|
public ArraySwipeAdapter(Context context, int resource) {
|
||||||
super(context, resource);
|
super(context, resource);
|
||||||
|
|
@ -41,15 +42,15 @@ public abstract class ArraySwipeAdapter<T> extends ArrayAdapter implements Swipe
|
||||||
super(context, resource, textViewResourceId, objects);
|
super(context, resource, textViewResourceId, objects);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void notifyDatasetChanged() {
|
|
||||||
super.notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
boolean convertViewIsNull = convertView == null;
|
||||||
View v = super.getView(position, convertView, parent);
|
View v = super.getView(position, convertView, parent);
|
||||||
mItemManger.bind(v, position);
|
if(convertViewIsNull){
|
||||||
|
mItemManger.initialize(v, position);
|
||||||
|
}else{
|
||||||
|
mItemManger.updateConvertView(v, position);
|
||||||
|
}
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,8 +5,9 @@ import android.view.ViewGroup;
|
||||||
import android.widget.BaseAdapter;
|
import android.widget.BaseAdapter;
|
||||||
|
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
import com.daimajia.swipe.implments.SwipeItemAdapterMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
|
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
import com.daimajia.swipe.util.Attributes;
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
||||||
|
|
@ -14,7 +15,7 @@ import java.util.List;
|
||||||
|
|
||||||
public abstract class BaseSwipeAdapter extends BaseAdapter implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
public abstract class BaseSwipeAdapter extends BaseAdapter implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
||||||
|
|
||||||
protected SwipeItemMangerImpl mItemManger = new SwipeItemMangerImpl(this);
|
protected SwipeItemAdapterMangerImpl mItemManger = new SwipeItemAdapterMangerImpl(this);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* return the {@link com.daimajia.swipe.SwipeLayout} resource id, int the view item.
|
* return the {@link com.daimajia.swipe.SwipeLayout} resource id, int the view item.
|
||||||
|
|
@ -41,19 +42,16 @@ public abstract class BaseSwipeAdapter extends BaseAdapter implements SwipeItemM
|
||||||
*/
|
*/
|
||||||
public abstract void fillValues(int position, View convertView);
|
public abstract void fillValues(int position, View convertView);
|
||||||
|
|
||||||
@Override
|
|
||||||
public void notifyDatasetChanged() {
|
|
||||||
super.notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final View getView(int position, View convertView, ViewGroup parent) {
|
public final View getView(int position, View convertView, ViewGroup parent) {
|
||||||
View v = convertView;
|
View v = convertView;
|
||||||
if(v == null){
|
if(v == null){
|
||||||
v = generateView(position, parent);
|
v = generateView(position, parent);
|
||||||
|
mItemManger.initialize(v, position);
|
||||||
|
}else{
|
||||||
|
mItemManger.updateConvertView(v, position);
|
||||||
}
|
}
|
||||||
mItemManger.bind(v, position);
|
|
||||||
fillValues(position, v);
|
fillValues(position, v);
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,8 +7,9 @@ import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
import com.daimajia.swipe.implments.SwipeItemAdapterMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
|
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
import com.daimajia.swipe.util.Attributes;
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
||||||
|
|
@ -16,7 +17,7 @@ import java.util.List;
|
||||||
|
|
||||||
public abstract class CursorSwipeAdapter extends CursorAdapter implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
public abstract class CursorSwipeAdapter extends CursorAdapter implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
||||||
|
|
||||||
private SwipeItemMangerImpl mItemManger = new SwipeItemMangerImpl(this);
|
private SwipeItemAdapterMangerImpl mItemManger = new SwipeItemAdapterMangerImpl(this);
|
||||||
|
|
||||||
protected CursorSwipeAdapter(Context context, Cursor c, boolean autoRequery) {
|
protected CursorSwipeAdapter(Context context, Cursor c, boolean autoRequery) {
|
||||||
super(context, c, autoRequery);
|
super(context, c, autoRequery);
|
||||||
|
|
@ -28,8 +29,13 @@ public abstract class CursorSwipeAdapter extends CursorAdapter implements SwipeI
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
boolean convertViewIsNull = convertView == null;
|
||||||
View v = super.getView(position, convertView, parent);
|
View v = super.getView(position, convertView, parent);
|
||||||
mItemManger.bind(v, position);
|
if(convertViewIsNull){
|
||||||
|
mItemManger.initialize(v, position);
|
||||||
|
}else{
|
||||||
|
mItemManger.updateConvertView(v, position);
|
||||||
|
}
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -48,11 +54,6 @@ public abstract class CursorSwipeAdapter extends CursorAdapter implements SwipeI
|
||||||
mItemManger.closeAllExcept(layout);
|
mItemManger.closeAllExcept(layout);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void closeAllItems() {
|
|
||||||
mItemManger.closeAllItems();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<Integer> getOpenItems() {
|
public List<Integer> getOpenItems() {
|
||||||
return mItemManger.getOpenItems();
|
return mItemManger.getOpenItems();
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ import android.support.v7.widget.RecyclerView;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
import com.daimajia.swipe.implments.SwipeItemRecyclerMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
import com.daimajia.swipe.util.Attributes;
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
@ -13,7 +13,7 @@ import java.util.List;
|
||||||
|
|
||||||
public abstract class RecyclerSwipeAdapter<VH extends RecyclerView.ViewHolder> extends RecyclerView.Adapter<VH> implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
public abstract class RecyclerSwipeAdapter<VH extends RecyclerView.ViewHolder> extends RecyclerView.Adapter<VH> implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
||||||
|
|
||||||
public SwipeItemMangerImpl mItemManger = new SwipeItemMangerImpl(this);
|
public SwipeItemRecyclerMangerImpl mItemManger = new SwipeItemRecyclerMangerImpl(this);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public abstract VH onCreateViewHolder(ViewGroup parent, int viewType);
|
public abstract VH onCreateViewHolder(ViewGroup parent, int viewType);
|
||||||
|
|
@ -21,11 +21,6 @@ public abstract class RecyclerSwipeAdapter<VH extends RecyclerView.ViewHolder> e
|
||||||
@Override
|
@Override
|
||||||
public abstract void onBindViewHolder(VH viewHolder, final int position);
|
public abstract void onBindViewHolder(VH viewHolder, final int position);
|
||||||
|
|
||||||
@Override
|
|
||||||
public void notifyDatasetChanged() {
|
|
||||||
super.notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void openItem(int position) {
|
public void openItem(int position) {
|
||||||
mItemManger.openItem(position);
|
mItemManger.openItem(position);
|
||||||
|
|
|
||||||
|
|
@ -7,6 +7,7 @@ import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
|
import com.daimajia.swipe.implments.SwipeItemAdapterMangerImpl;
|
||||||
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
||||||
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
|
|
@ -16,7 +17,7 @@ import java.util.List;
|
||||||
|
|
||||||
public abstract class SimpleCursorSwipeAdapter extends SimpleCursorAdapter implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
public abstract class SimpleCursorSwipeAdapter extends SimpleCursorAdapter implements SwipeItemMangerInterface, SwipeAdapterInterface {
|
||||||
|
|
||||||
private SwipeItemMangerImpl mItemManger = new SwipeItemMangerImpl(this);
|
private SwipeItemAdapterMangerImpl mItemManger = new SwipeItemAdapterMangerImpl(this);
|
||||||
|
|
||||||
protected SimpleCursorSwipeAdapter(Context context, int layout, Cursor c, String[] from, int[] to, int flags) {
|
protected SimpleCursorSwipeAdapter(Context context, int layout, Cursor c, String[] from, int[] to, int flags) {
|
||||||
super(context, layout, c, from, to, flags);
|
super(context, layout, c, from, to, flags);
|
||||||
|
|
@ -28,8 +29,13 @@ public abstract class SimpleCursorSwipeAdapter extends SimpleCursorAdapter imple
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
boolean convertViewIsNull = convertView == null;
|
||||||
View v = super.getView(position, convertView, parent);
|
View v = super.getView(position, convertView, parent);
|
||||||
mItemManger.bind(v, position);
|
if(convertViewIsNull){
|
||||||
|
mItemManger.initialize(v, position);
|
||||||
|
}else{
|
||||||
|
mItemManger.updateConvertView(v, position);
|
||||||
|
}
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,66 @@
|
||||||
|
package com.daimajia.swipe.implments;
|
||||||
|
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.BaseAdapter;
|
||||||
|
|
||||||
|
import com.daimajia.swipe.SimpleSwipeListener;
|
||||||
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SwipeItemMangerImpl is a helper class to help all the adapters to maintain open status.
|
||||||
|
*/
|
||||||
|
public class SwipeItemAdapterMangerImpl extends SwipeItemMangerImpl{
|
||||||
|
|
||||||
|
protected BaseAdapter mAdapter;
|
||||||
|
|
||||||
|
public SwipeItemAdapterMangerImpl(BaseAdapter adapter) {
|
||||||
|
super(adapter);
|
||||||
|
this.mAdapter = adapter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void initialize(View target, int position) {
|
||||||
|
int resId = getSwipeLayoutId(position);
|
||||||
|
|
||||||
|
OnLayoutListener onLayoutListener = new OnLayoutListener(position);
|
||||||
|
SwipeLayout swipeLayout = (SwipeLayout) target.findViewById(resId);
|
||||||
|
if (swipeLayout == null)
|
||||||
|
throw new IllegalStateException("can not find SwipeLayout in target view");
|
||||||
|
|
||||||
|
SwipeMemory swipeMemory = new SwipeMemory(position);
|
||||||
|
swipeLayout.addSwipeListener(swipeMemory);
|
||||||
|
swipeLayout.addOnLayoutListener(onLayoutListener);
|
||||||
|
swipeLayout.setTag(resId, new ValueBox(position, swipeMemory, onLayoutListener));
|
||||||
|
|
||||||
|
mShownLayouts.add(swipeLayout);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateConvertView(View target, int position) {
|
||||||
|
int resId = getSwipeLayoutId(position);
|
||||||
|
|
||||||
|
SwipeLayout swipeLayout = (SwipeLayout) target.findViewById(resId);
|
||||||
|
if (swipeLayout == null)
|
||||||
|
throw new IllegalStateException("can not find SwipeLayout in target view");
|
||||||
|
|
||||||
|
ValueBox valueBox = (ValueBox) swipeLayout.getTag(resId);
|
||||||
|
valueBox.swipeMemory.setPosition(position);
|
||||||
|
valueBox.onLayoutListener.setPosition(position);
|
||||||
|
valueBox.position = position;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bindView(View target, int position){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -1,6 +1,8 @@
|
||||||
package com.daimajia.swipe.implments;
|
package com.daimajia.swipe.implments;
|
||||||
|
|
||||||
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
import android.widget.BaseAdapter;
|
||||||
|
|
||||||
import com.daimajia.swipe.SimpleSwipeListener;
|
import com.daimajia.swipe.SimpleSwipeListener;
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
|
|
@ -9,7 +11,7 @@ import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
import com.daimajia.swipe.util.Attributes;
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Arrays;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
@ -17,7 +19,7 @@ import java.util.Set;
|
||||||
/**
|
/**
|
||||||
* SwipeItemMangerImpl is a helper class to help all the adapters to maintain open status.
|
* SwipeItemMangerImpl is a helper class to help all the adapters to maintain open status.
|
||||||
*/
|
*/
|
||||||
public class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
public abstract class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
||||||
|
|
||||||
private Attributes.Mode mode = Attributes.Mode.Single;
|
private Attributes.Mode mode = Attributes.Mode.Single;
|
||||||
public final int INVALID_POSITION = -1;
|
public final int INVALID_POSITION = -1;
|
||||||
|
|
@ -27,13 +29,27 @@ public class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
||||||
protected Set<Integer> mOpenPositions = new HashSet<Integer>();
|
protected Set<Integer> mOpenPositions = new HashSet<Integer>();
|
||||||
protected Set<SwipeLayout> mShownLayouts = new HashSet<SwipeLayout>();
|
protected Set<SwipeLayout> mShownLayouts = new HashSet<SwipeLayout>();
|
||||||
|
|
||||||
protected SwipeAdapterInterface swipeAdapterInterface;
|
protected BaseAdapter mBaseAdapter;
|
||||||
|
protected RecyclerView.Adapter mRecyclerAdapter;
|
||||||
|
|
||||||
public SwipeItemMangerImpl(SwipeAdapterInterface swipeAdapterInterface) {
|
public SwipeItemMangerImpl(BaseAdapter adapter) {
|
||||||
if (swipeAdapterInterface == null)
|
if (adapter == null)
|
||||||
throw new IllegalArgumentException("SwipeAdapterInterface can not be null");
|
throw new IllegalArgumentException("Adapter can not be null");
|
||||||
|
|
||||||
this.swipeAdapterInterface = swipeAdapterInterface;
|
if (!(adapter instanceof SwipeItemMangerInterface))
|
||||||
|
throw new IllegalArgumentException("adapter should implement the SwipeAdapterInterface");
|
||||||
|
|
||||||
|
this.mBaseAdapter = adapter;
|
||||||
|
}
|
||||||
|
|
||||||
|
public SwipeItemMangerImpl(RecyclerView.Adapter adapter) {
|
||||||
|
if (adapter == null)
|
||||||
|
throw new IllegalArgumentException("Adapter can not be null");
|
||||||
|
|
||||||
|
if (!(adapter instanceof SwipeItemMangerInterface))
|
||||||
|
throw new IllegalArgumentException("adapter should implement the SwipeAdapterInterface");
|
||||||
|
|
||||||
|
this.mRecyclerAdapter = adapter;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Attributes.Mode getMode() {
|
public Attributes.Mode getMode() {
|
||||||
|
|
@ -47,24 +63,21 @@ public class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
||||||
mOpenPosition = INVALID_POSITION;
|
mOpenPosition = INVALID_POSITION;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void bind(View view, int position) {
|
/* initialize and updateConvertView used for AdapterManagerImpl */
|
||||||
int resId = swipeAdapterInterface.getSwipeLayoutResourceId(position);
|
public abstract void initialize(View target, int position);
|
||||||
SwipeLayout swipeLayout = (SwipeLayout) view.findViewById(resId);
|
|
||||||
if (swipeLayout == null)
|
|
||||||
throw new IllegalStateException("can not find SwipeLayout in target view");
|
|
||||||
|
|
||||||
if (swipeLayout.getTag(resId) == null) {
|
public abstract void updateConvertView(View target, int position);
|
||||||
OnLayoutListener onLayoutListener = new OnLayoutListener(position);
|
|
||||||
SwipeMemory swipeMemory = new SwipeMemory(position);
|
/* bindView used for RecyclerViewManagerImpl */
|
||||||
swipeLayout.addSwipeListener(swipeMemory);
|
public abstract void bindView(View target, int position);
|
||||||
swipeLayout.addOnLayoutListener(onLayoutListener);
|
|
||||||
swipeLayout.setTag(resId, new ValueBox(position, swipeMemory, onLayoutListener));
|
public int getSwipeLayoutId(int position) {
|
||||||
mShownLayouts.add(swipeLayout);
|
if (mBaseAdapter != null) {
|
||||||
|
return ((SwipeAdapterInterface) (mBaseAdapter)).getSwipeLayoutResourceId(position);
|
||||||
|
} else if (mRecyclerAdapter != null) {
|
||||||
|
return ((SwipeAdapterInterface) (mRecyclerAdapter)).getSwipeLayoutResourceId(position);
|
||||||
} else {
|
} else {
|
||||||
ValueBox valueBox = (ValueBox) swipeLayout.getTag(resId);
|
return -1;
|
||||||
valueBox.swipeMemory.setPosition(position);
|
|
||||||
valueBox.onLayoutListener.setPosition(position);
|
|
||||||
valueBox.position = position;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -76,7 +89,11 @@ public class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
||||||
} else {
|
} else {
|
||||||
mOpenPosition = position;
|
mOpenPosition = position;
|
||||||
}
|
}
|
||||||
swipeAdapterInterface.notifyDatasetChanged();
|
if (mBaseAdapter != null) {
|
||||||
|
mBaseAdapter.notifyDataSetChanged();
|
||||||
|
} else if (mRecyclerAdapter != null) {
|
||||||
|
mRecyclerAdapter.notifyDataSetChanged();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -87,7 +104,11 @@ public class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
||||||
if (mOpenPosition == position)
|
if (mOpenPosition == position)
|
||||||
mOpenPosition = INVALID_POSITION;
|
mOpenPosition = INVALID_POSITION;
|
||||||
}
|
}
|
||||||
swipeAdapterInterface.notifyDatasetChanged();
|
if (mBaseAdapter != null) {
|
||||||
|
mBaseAdapter.notifyDataSetChanged();
|
||||||
|
} else if (mRecyclerAdapter != null) {
|
||||||
|
mRecyclerAdapter.notifyDataSetChanged();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -120,7 +141,7 @@ public class SwipeItemMangerImpl implements SwipeItemMangerInterface {
|
||||||
if (mode == Attributes.Mode.Multiple) {
|
if (mode == Attributes.Mode.Multiple) {
|
||||||
return new ArrayList<Integer>(mOpenPositions);
|
return new ArrayList<Integer>(mOpenPositions);
|
||||||
} else {
|
} else {
|
||||||
return Collections.singletonList(mOpenPosition);
|
return Arrays.asList(mOpenPosition);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,63 @@
|
||||||
|
package com.daimajia.swipe.implments;
|
||||||
|
|
||||||
|
import android.support.v7.widget.RecyclerView;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
import com.daimajia.swipe.SimpleSwipeListener;
|
||||||
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
|
import com.daimajia.swipe.interfaces.SwipeAdapterInterface;
|
||||||
|
import com.daimajia.swipe.interfaces.SwipeItemMangerInterface;
|
||||||
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SwipeItemRecyclerMangerImpl is a helper class to help the RecyclerView to maintain open status.
|
||||||
|
*/
|
||||||
|
public class SwipeItemRecyclerMangerImpl extends SwipeItemMangerImpl{
|
||||||
|
|
||||||
|
protected RecyclerView.Adapter mAdapter;
|
||||||
|
|
||||||
|
public SwipeItemRecyclerMangerImpl(RecyclerView.Adapter adapter) {
|
||||||
|
super(adapter);
|
||||||
|
this.mAdapter = adapter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bindView(View target, int position) {
|
||||||
|
int resId = getSwipeLayoutId(position);
|
||||||
|
|
||||||
|
OnLayoutListener onLayoutListener = new OnLayoutListener(position);
|
||||||
|
SwipeLayout swipeLayout = (SwipeLayout) target.findViewById(resId);
|
||||||
|
if (swipeLayout == null)
|
||||||
|
throw new IllegalStateException("can not find SwipeLayout in target view");
|
||||||
|
|
||||||
|
if (swipeLayout.getTag(resId) == null) {
|
||||||
|
SwipeMemory swipeMemory = new SwipeMemory(position);
|
||||||
|
swipeLayout.addSwipeListener(swipeMemory);
|
||||||
|
swipeLayout.addOnLayoutListener(onLayoutListener);
|
||||||
|
swipeLayout.setTag(resId, new ValueBox(position, swipeMemory, onLayoutListener));
|
||||||
|
mShownLayouts.add(swipeLayout);
|
||||||
|
} else {
|
||||||
|
ValueBox valueBox = (ValueBox) swipeLayout.getTag(resId);
|
||||||
|
valueBox.swipeMemory.setPosition(position);
|
||||||
|
valueBox.onLayoutListener.setPosition(position);
|
||||||
|
valueBox.position = position;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void initialize(View target, int position) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateConvertView(View target, int position) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -1,9 +1,5 @@
|
||||||
package com.daimajia.swipe.interfaces;
|
package com.daimajia.swipe.interfaces;
|
||||||
|
|
||||||
public interface SwipeAdapterInterface {
|
public interface SwipeAdapterInterface {
|
||||||
|
public int getSwipeLayoutResourceId(int position);
|
||||||
int getSwipeLayoutResourceId(int position);
|
|
||||||
|
|
||||||
void notifyDatasetChanged();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,29 +1,30 @@
|
||||||
package com.daimajia.swipe.interfaces;
|
package com.daimajia.swipe.interfaces;
|
||||||
|
|
||||||
import com.daimajia.swipe.SwipeLayout;
|
import com.daimajia.swipe.SwipeLayout;
|
||||||
|
import com.daimajia.swipe.implments.SwipeItemMangerImpl;
|
||||||
import com.daimajia.swipe.util.Attributes;
|
import com.daimajia.swipe.util.Attributes;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public interface SwipeItemMangerInterface {
|
public interface SwipeItemMangerInterface {
|
||||||
|
|
||||||
void openItem(int position);
|
public void openItem(int position);
|
||||||
|
|
||||||
void closeItem(int position);
|
public void closeItem(int position);
|
||||||
|
|
||||||
void closeAllExcept(SwipeLayout layout);
|
public void closeAllExcept(SwipeLayout layout);
|
||||||
|
|
||||||
void closeAllItems();
|
public void closeAllItems();
|
||||||
|
|
||||||
List<Integer> getOpenItems();
|
public List<Integer> getOpenItems();
|
||||||
|
|
||||||
List<SwipeLayout> getOpenLayouts();
|
public List<SwipeLayout> getOpenLayouts();
|
||||||
|
|
||||||
void removeShownLayouts(SwipeLayout layout);
|
public void removeShownLayouts(SwipeLayout layout);
|
||||||
|
|
||||||
boolean isOpen(int position);
|
public boolean isOpen(int position);
|
||||||
|
|
||||||
Attributes.Mode getMode();
|
public Attributes.Mode getMode();
|
||||||
|
|
||||||
void setMode(Attributes.Mode mode);
|
public void setMode(Attributes.Mode mode);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue