From 1805793c7cea8a3c56a8111e0a80d7ac5da95f63 Mon Sep 17 00:00:00 2001 From: Allan Wang Date: Mon, 12 Jun 2017 20:01:34 -0700 Subject: Add sliding activities --- .../kotlin/ca/allanwang/kau/utils/ContextUtils.kt | 22 ++++++++++++++++++++++ library/src/main/res/anim/kau_fade_in.xml | 5 +++++ library/src/main/res/anim/kau_fade_out.xml | 5 +++++ .../src/main/res/anim/kau_slide_out_right_top.xml | 8 ++++++++ 4 files changed, 40 insertions(+) create mode 100644 library/src/main/res/anim/kau_fade_in.xml create mode 100644 library/src/main/res/anim/kau_fade_out.xml create mode 100644 library/src/main/res/anim/kau_slide_out_right_top.xml (limited to 'library') diff --git a/library/src/main/kotlin/ca/allanwang/kau/utils/ContextUtils.kt b/library/src/main/kotlin/ca/allanwang/kau/utils/ContextUtils.kt index e2c1eb8..87bc547 100644 --- a/library/src/main/kotlin/ca/allanwang/kau/utils/ContextUtils.kt +++ b/library/src/main/kotlin/ca/allanwang/kau/utils/ContextUtils.kt @@ -9,6 +9,7 @@ import android.net.ConnectivityManager import android.os.Bundle import android.os.Handler import android.support.annotation.* +import android.support.v4.app.ActivityOptionsCompat import android.support.v4.content.ContextCompat import android.util.TypedValue import android.widget.Toast @@ -39,6 +40,27 @@ fun Context.startActivity(clazz: Class, clearStack: Boolean = fals if (this is Activity && clearStack) finish() } +/** + * Bring in activity from the right + */ +fun Context.startActivitySlideIn(clazz: Class, clearStack: Boolean = false, intentBuilder: Intent.() -> Unit = {}, bundleBuilder: Bundle.() -> Unit = {}) { + val bundle = ActivityOptionsCompat.makeCustomAnimation(this, R.anim.kau_slide_in_right, R.anim.kau_fade_out).toBundle() + bundle.bundleBuilder() + startActivity(clazz, clearStack, intentBuilder, bundle) +} + +/** + * Bring in activity from behind while pushing the current activity to the right + * This replicates the exit animation of a sliding activity, but is a forward creation + * For the animation to work, the previous activity should not be in the stack (otherwise you wouldn't need this in the first place) + * Consequently, the stack will be cleared by default + */ +fun Context.startActivitySlideOut(clazz: Class, clearStack: Boolean = true, intentBuilder: Intent.() -> Unit = {}, bundleBuilder: Bundle.() -> Unit = {}) { + val bundle = ActivityOptionsCompat.makeCustomAnimation(this, R.anim.kau_fade_in, R.anim.kau_slide_out_right_top).toBundle() + bundle.bundleBuilder() + startActivity(clazz, clearStack, intentBuilder, bundle) +} + var Activity.navigationBarColor: Int get() = if (buildIsLollipopAndUp) window.navigationBarColor else Color.BLACK set(value) { diff --git a/library/src/main/res/anim/kau_fade_in.xml b/library/src/main/res/anim/kau_fade_in.xml new file mode 100644 index 0000000..03312a2 --- /dev/null +++ b/library/src/main/res/anim/kau_fade_in.xml @@ -0,0 +1,5 @@ + + \ No newline at end of file diff --git a/library/src/main/res/anim/kau_fade_out.xml b/library/src/main/res/anim/kau_fade_out.xml new file mode 100644 index 0000000..322befc --- /dev/null +++ b/library/src/main/res/anim/kau_fade_out.xml @@ -0,0 +1,5 @@ + + \ No newline at end of file diff --git a/library/src/main/res/anim/kau_slide_out_right_top.xml b/library/src/main/res/anim/kau_slide_out_right_top.xml new file mode 100644 index 0000000..5b63474 --- /dev/null +++ b/library/src/main/res/anim/kau_slide_out_right_top.xml @@ -0,0 +1,8 @@ + + + + \ No newline at end of file -- cgit v1.2.3