diff options
author | Jamie Gennis <jgennis@google.com> | 2012-12-17 18:30:46 -0800 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2012-12-17 18:30:46 -0800 |
commit | d2a21d7fee7ba3c9596baf16cadc76dd607a5cb1 (patch) | |
tree | 8e6de4cb91b6c052d3b0da4d1d9071675f3d22e9 /services/java | |
parent | dfb46cea6282ac9321b70af6c9a6f6b5396cde2e (diff) | |
parent | 3be73abc69eaef80c6d27169ca5f15e283a9debc (diff) | |
download | frameworks_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-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 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; |