diff options
author | Allan Wang <me@allanwang.ca> | 2017-07-05 14:47:58 -0700 |
---|---|---|
committer | Allan Wang <me@allanwang.ca> | 2017-07-05 14:47:58 -0700 |
commit | 36471abc904ff4aa3109bd06efbc3ed493f082b2 (patch) | |
tree | 7b7f8a9b7828d0171ad2b5854a67b0108e772de7 /core/src/main/kotlin/ca/allanwang/kau/swipe/RelativeSlider.kt | |
parent | 10e2ee9d4f105d9737b98b1caacf5e6ccb1c3c7d (diff) | |
download | kau-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.kt | 27 |
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 { |