aboutsummaryrefslogtreecommitdiff
path: root/core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt
diff options
context:
space:
mode:
authorAllan Wang <me@allanwang.ca>2017-07-05 14:47:58 -0700
committerAllan Wang <me@allanwang.ca>2017-07-05 14:47:58 -0700
commit36471abc904ff4aa3109bd06efbc3ed493f082b2 (patch)
tree7b7f8a9b7828d0171ad2b5854a67b0108e772de7 /core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt
parent10e2ee9d4f105d9737b98b1caacf5e6ccb1c3c7d (diff)
downloadkau-36471abc904ff4aa3109bd06efbc3ed493f082b2.tar.gz
kau-36471abc904ff4aa3109bd06efbc3ed493f082b2.tar.bz2
kau-36471abc904ff4aa3109bd06efbc3ed493f082b2.zip
Setup swipe for all directions
Diffstat (limited to 'core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt')
-rw-r--r--core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt27
1 files changed, 22 insertions, 5 deletions
diff --git a/core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt b/core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt
index ee86ff2..5d54134 100644
--- a/core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt
+++ b/core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt
@@ -17,17 +17,34 @@ class RelativeSlider(var curPage: SwipeBackPage) : SwipeListener {
else curPage.removeListener(this)
}
- override fun onScroll(percent: Float, px: Int) {
+ /**
+ * Set offset of previous page based on the edge flag and percentage scrolled
+ */
+ override fun onScroll(percent: Float, px: Int, edgeFlag: Int) {
if (offset == 0f) return //relative slider is not enabled
val page = SwipeBackHelper.getPrePage(curPage) ?: return
- page.swipeBackLayout.x = Math.min(-offset * Math.max(1 - percent, 0f) + DEFAULT_OFFSET, 0f)
- if (percent == 0f) page.swipeBackLayout.x = 0f
+ if (percent == 0f) {
+ page.swipeBackLayout.x = 0f
+ page.swipeBackLayout.y = 0f
+ return
+ }
+ when (edgeFlag) {
+ SwipeBackLayout.EDGE_LEFT -> page.swipeBackLayout.x = Math.min(-offset * Math.max(1 - percent, 0f) + DEFAULT_OFFSET, 0f)
+ SwipeBackLayout.EDGE_RIGHT -> page.swipeBackLayout.x = Math.min(offset * Math.max(1 - percent, 0f) - DEFAULT_OFFSET, 0f)
+ SwipeBackLayout.EDGE_TOP -> page.swipeBackLayout.y = Math.min(-offset * Math.max(1 - percent, 0f) + DEFAULT_OFFSET, 0f)
+ SwipeBackLayout.EDGE_BOTTOM -> page.swipeBackLayout.y = Math.min(offset * Math.max(1 - percent, 0f) - DEFAULT_OFFSET, 0f)
+ }
}
override fun onEdgeTouch() {}
- override fun onScrollToClose() {
- SwipeBackHelper.getPrePage(curPage)?.swipeBackLayout?.x = 0f
+ /**
+ * Reset offsets for previous page
+ */
+ override fun onScrollToClose(edgeFlag: Int) {
+ val prePage = SwipeBackHelper.getPrePage(curPage) ?: return
+ prePage.swipeBackLayout.x = 0f
+ prePage.swipeBackLayout.y = 0f
}
companion object {