diff options
| author | 2012-12-17 18:30:46 -0800 | |
|---|---|---|
| committer | 2012-12-17 18:30:46 -0800 | |
| commit | d2a21d7fee7ba3c9596baf16cadc76dd607a5cb1 (patch) | |
| tree | 8e6de4cb91b6c052d3b0da4d1d9071675f3d22e9 | |
| parent | dfb46cea6282ac9321b70af6c9a6f6b5396cde2e (diff) | |
| parent | 3be73abc69eaef80c6d27169ca5f15e283a9debc (diff) | |
Merge "Fade recents thumbnail to transparent earlier." into jb-mr1.1-dev
| -rwxr-xr-x | services/java/com/android/server/wm/WindowManagerService.java | 20 |
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 746254e94a9f..5b9fc9afb33d 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; |