summaryrefslogtreecommitdiffstats
path: root/services/java
diff options
context:
space:
mode:
authorJamie Gennis <jgennis@google.com>2012-12-17 18:30:46 -0800
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-12-17 18:30:46 -0800
commitd2a21d7fee7ba3c9596baf16cadc76dd607a5cb1 (patch)
tree8e6de4cb91b6c052d3b0da4d1d9071675f3d22e9 /services/java
parentdfb46cea6282ac9321b70af6c9a6f6b5396cde2e (diff)
parent3be73abc69eaef80c6d27169ca5f15e283a9debc (diff)
downloadframeworks_base-d2a21d7fee7ba3c9596baf16cadc76dd607a5cb1.zip
frameworks_base-d2a21d7fee7ba3c9596baf16cadc76dd607a5cb1.tar.gz
frameworks_base-d2a21d7fee7ba3c9596baf16cadc76dd607a5cb1.tar.bz2
Merge "Fade recents thumbnail to transparent earlier." into jb-mr1.1-dev
Diffstat (limited to 'services/java')
-rwxr-xr-xservices/java/com/android/server/wm/WindowManagerService.java20
1 files changed, 17 insertions, 3 deletions
diff --git a/services/java/com/android/server/wm/WindowManagerService.java b/services/java/com/android/server/wm/WindowManagerService.java
index 746254e..5b9fc9a 100755
--- a/services/java/com/android/server/wm/WindowManagerService.java
+++ b/services/java/com/android/server/wm/WindowManagerService.java
@@ -268,6 +268,9 @@ public class WindowManagerService extends IWindowManager.Stub
/** Amount of time (in milliseconds) to delay before declaring a window freeze timeout. */
static final int WINDOW_FREEZE_TIMEOUT_DURATION = 2000;
+ /** Fraction of animation at which the recents thumbnail becomes completely transparent */
+ static final float RECENTS_THUMBNAIL_FADEOUT_FRACTION = 0.25f;
+
/**
* If true, the window manager will do its own custom freezing and general
* management of the screen during rotation.
@@ -3383,13 +3386,24 @@ public class WindowManagerService extends IWindowManager.Stub
Animation scale = new ScaleAnimation(1, scaleW, 1, scaleH,
computePivot(mNextAppTransitionStartX, 1 / scaleW),
computePivot(mNextAppTransitionStartY, 1 / scaleH));
- AnimationSet set = new AnimationSet(true);
+ AnimationSet set = new AnimationSet(false);
Animation alpha = new AlphaAnimation(1, 0);
scale.setDuration(duration);
- scale.setInterpolator(
- new DecelerateInterpolator(THUMBNAIL_ANIMATION_DECELERATE_FACTOR));
+ scale.setInterpolator(AnimationUtils.loadInterpolator(mContext,
+ com.android.internal.R.interpolator.decelerate_quad));
set.addAnimation(scale);
alpha.setDuration(duration);
+ alpha.setInterpolator(new Interpolator() {
+ @Override
+ public float getInterpolation(float input) {
+ if (input < RECENTS_THUMBNAIL_FADEOUT_FRACTION) {
+ // linear response
+ return input / RECENTS_THUMBNAIL_FADEOUT_FRACTION;
+ }
+ // complete
+ return 1;
+ }
+ });
set.addAnimation(alpha);
set.setFillBefore(true);
a = set;