diff options
author | John Spurlock <jspurlock@google.com> | 2014-08-03 11:47:35 -0400 |
---|---|---|
committer | John Spurlock <jspurlock@google.com> | 2014-08-03 11:47:35 -0400 |
commit | 19328fab0e7d1509c4c2f9276900dbd87bce81ea (patch) | |
tree | df189866a58a2bfa592518236ce7a081d4c92434 /packages/SystemUI/src | |
parent | 1c18285c36a0cf202dcf737c96766638e1e56c5d (diff) | |
download | frameworks_base-19328fab0e7d1509c4c2f9276900dbd87bce81ea.zip frameworks_base-19328fab0e7d1509c4c2f9276900dbd87bce81ea.tar.gz frameworks_base-19328fab0e7d1509c4c2f9276900dbd87bce81ea.tar.bz2 |
QS: Fix detail clip reverse transition.
Give it a layer during the transition to workaround a recent
regression in the clip animation.
Also:
- Dial down the transition alpha a bit
- Do a delayed reverse transition on exit
Change-Id: I622d6eb863d6186293b0126dda8fca3a04a80a85
Diffstat (limited to 'packages/SystemUI/src')
-rw-r--r-- | packages/SystemUI/src/com/android/systemui/qs/QSDetailClipper.java | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/packages/SystemUI/src/com/android/systemui/qs/QSDetailClipper.java b/packages/SystemUI/src/com/android/systemui/qs/QSDetailClipper.java index c0daf72..9c1ff9d 100644 --- a/packages/SystemUI/src/com/android/systemui/qs/QSDetailClipper.java +++ b/packages/SystemUI/src/com/android/systemui/qs/QSDetailClipper.java @@ -51,16 +51,27 @@ public class QSDetailClipper { if (listener != null) { mAnimator.addListener(listener); } + mDetail.setLayerType(View.LAYER_TYPE_HARDWARE, null); if (in) { mBackground.startTransition((int)(mAnimator.getDuration() * 0.6)); mAnimator.addListener(mVisibleOnStart); mAnimator.start(); } else { + mDetail.postDelayed(mReverseBackground, (long)(mAnimator.getDuration() * 0.65)); mAnimator.addListener(mGoneOnEnd); mAnimator.reverse(); } } + private final Runnable mReverseBackground = new Runnable() { + @Override + public void run() { + if (mAnimator != null) { + mBackground.reverseTransition((int)(mAnimator.getDuration() * 0.35)); + } + } + }; + private final AnimatorListenerAdapter mVisibleOnStart = new AnimatorListenerAdapter() { @Override public void onAnimationStart(Animator animation) { @@ -68,6 +79,7 @@ public class QSDetailClipper { } public void onAnimationEnd(Animator animation) { + mDetail.setLayerType(View.LAYER_TYPE_NONE, null); mAnimator = null; } }; @@ -75,6 +87,7 @@ public class QSDetailClipper { private final AnimatorListenerAdapter mGoneOnEnd = new AnimatorListenerAdapter() { @Override public void onAnimationEnd(Animator animation) { + mDetail.setLayerType(View.LAYER_TYPE_NONE, null); mDetail.setVisibility(View.GONE); mBackground.resetTransition(); mAnimator = null; |