summaryrefslogtreecommitdiffstats
path: root/packages/SystemUI/src
diff options
context:
space:
mode:
authorJohn Spurlock <jspurlock@google.com>2014-08-03 11:47:35 -0400
committerJohn Spurlock <jspurlock@google.com>2014-08-03 11:47:35 -0400
commit19328fab0e7d1509c4c2f9276900dbd87bce81ea (patch)
treedf189866a58a2bfa592518236ce7a081d4c92434 /packages/SystemUI/src
parent1c18285c36a0cf202dcf737c96766638e1e56c5d (diff)
downloadframeworks_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.java13
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;