blob: 92ad48518ff940b7c3548cfae7521cdafda5c4ba [file] [log] [blame]
Craig Mautner764983d2012-03-22 11:37:36 -07001// Copyright 2012 Google Inc. All Rights Reserved.
2
3package com.android.server.wm;
4
5import static android.view.WindowManager.LayoutParams.FLAG_SHOW_WALLPAPER;
Craig Mautnerf12100e2012-06-25 11:13:24 -07006import static android.view.WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED;
Craig Mautner764983d2012-03-22 11:37:36 -07007
Craig Mautnera608b882012-03-30 13:03:49 -07008import static com.android.server.wm.WindowManagerService.LayoutFields.SET_UPDATE_ROTATION;
9import static com.android.server.wm.WindowManagerService.LayoutFields.SET_WALLPAPER_MAY_CHANGE;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -070010import static com.android.server.wm.WindowManagerService.LayoutFields.SET_FORCE_HIDING_CHANGED;
Craig Mautner2639da52012-07-09 09:39:06 -070011import static com.android.server.wm.WindowManagerService.LayoutFields.SET_ORIENTATION_CHANGE_COMPLETE;
Craig Mautner96868332012-12-04 14:29:11 -080012import static com.android.server.wm.WindowManagerService.LayoutFields.SET_WALLPAPER_ACTION_PENDING;
Craig Mautnera608b882012-03-30 13:03:49 -070013
Craig Mautner764983d2012-03-22 11:37:36 -070014import android.content.Context;
Dianne Hackborn98129732012-11-01 16:28:16 -070015import android.os.Debug;
Craig Mautner764983d2012-03-22 11:37:36 -070016import android.os.SystemClock;
17import android.util.Log;
18import android.util.Slog;
Craig Mautnera91f9e22012-09-14 16:22:08 -070019import android.util.SparseArray;
Craig Mautner76a71652012-09-03 23:23:58 -070020import android.util.SparseIntArray;
Dianne Hackborn529e7442012-11-01 14:22:28 -070021import android.util.TimeUtils;
Craig Mautner1420b932012-12-28 17:14:38 -080022import android.util.TypedValue;
Craig Mautner6881a102012-07-27 13:04:51 -070023import android.view.Display;
Craig Mautner764983d2012-03-22 11:37:36 -070024import android.view.Surface;
Craig Mautner764983d2012-03-22 11:37:36 -070025import android.view.WindowManagerPolicy;
26import android.view.animation.Animation;
Craig Mautner764983d2012-03-22 11:37:36 -070027
Craig Mautner496bdbb2013-02-14 09:32:55 -080028import com.android.server.wm.DisplayContent.AppTokenIterator;
Craig Mautner66f78d72012-12-04 16:46:50 -080029import com.android.server.wm.WindowManagerService.DisplayContentsIterator;
Dianne Hackborn529e7442012-11-01 14:22:28 -070030import com.android.server.wm.WindowManagerService.LayoutFields;
Craig Mautner764983d2012-03-22 11:37:36 -070031
Craig Mautnere7ae2502012-03-26 17:11:19 -070032import java.io.PrintWriter;
Dianne Hackborn0c2acff2012-04-12 15:17:07 -070033import java.util.ArrayList;
Craig Mautnere7ae2502012-03-26 17:11:19 -070034
Craig Mautner764983d2012-03-22 11:37:36 -070035/**
Craig Mautner764983d2012-03-22 11:37:36 -070036 * Singleton class that carries out the animations and Surface operations in a separate task
37 * on behalf of WindowManagerService.
38 */
39public class WindowAnimator {
Craig Mautnerbb1449b2012-03-23 16:11:14 -070040 private static final String TAG = "WindowAnimator";
Craig Mautner764983d2012-03-22 11:37:36 -070041
Craig Mautner1420b932012-12-28 17:14:38 -080042 /** Amount of time in milliseconds to animate the dim surface from one value to another,
43 * when no window animation is driving it. */
44 static final int DEFAULT_DIM_DURATION = 200;
45
Craig Mautner764983d2012-03-22 11:37:36 -070046 final WindowManagerService mService;
47 final Context mContext;
48 final WindowManagerPolicy mPolicy;
49
50 boolean mAnimating;
Craig Mautner01cd0e72012-06-18 10:19:11 -070051
Craig Mautner1caa3992012-06-22 09:46:48 -070052 final Runnable mAnimationRunnable;
53
Craig Mautner764983d2012-03-22 11:37:36 -070054 int mAdjResult;
55
Craig Mautner764983d2012-03-22 11:37:36 -070056 /** Time of current animation step. Reset on each iteration */
57 long mCurrentTime;
58
59 /** Skip repeated AppWindowTokens initialization. Note that AppWindowsToken's version of this
60 * is a long initialized to Long.MIN_VALUE so that it doesn't match this value on startup. */
Craig Mautner6fbda632012-07-03 09:26:39 -070061 private int mAnimTransactionSequence;
Craig Mautner764983d2012-03-22 11:37:36 -070062
Craig Mautnerae446592012-12-06 19:05:05 -080063 /** Window currently running an animation that has requested it be detached
64 * from the wallpaper. This means we need to ensure the wallpaper is
65 * visible behind it in case it animates in a way that would allow it to be
66 * seen. If multiple windows satisfy this, use the lowest window. */
Craig Mautnere7ae2502012-03-26 17:11:19 -070067 WindowState mWindowDetachedWallpaper = null;
Craig Mautner01cd0e72012-06-18 10:19:11 -070068
Dianne Hackborna4b7f2f2012-05-21 11:28:41 -070069 WindowStateAnimator mUniverseBackground = null;
70 int mAboveUniverseLayer = 0;
71
Craig Mautnera608b882012-03-30 13:03:49 -070072 int mBulkUpdateParams = 0;
73
Craig Mautnera91f9e22012-09-14 16:22:08 -070074 SparseArray<DisplayContentsAnimator> mDisplayContentsAnimators =
75 new SparseArray<WindowAnimator.DisplayContentsAnimator>();
Craig Mautnerd09cc4b2012-04-04 10:23:31 -070076
Craig Mautnerb47bbc32012-08-22 17:41:48 -070077 boolean mInitialized = false;
78
Craig Mautner178af592012-09-17 10:37:29 -070079 // forceHiding states.
80 static final int KEYGUARD_NOT_SHOWN = 0;
81 static final int KEYGUARD_ANIMATING_IN = 1;
82 static final int KEYGUARD_SHOWN = 2;
83 static final int KEYGUARD_ANIMATING_OUT = 3;
84 int mForceHiding = KEYGUARD_NOT_SHOWN;
85
86 private String forceHidingToString() {
87 switch (mForceHiding) {
88 case KEYGUARD_NOT_SHOWN: return "KEYGUARD_NOT_SHOWN";
89 case KEYGUARD_ANIMATING_IN: return "KEYGUARD_ANIMATING_IN";
90 case KEYGUARD_SHOWN: return "KEYGUARD_SHOWN";
91 case KEYGUARD_ANIMATING_OUT:return "KEYGUARD_ANIMATING_OUT";
92 default: return "KEYGUARD STATE UNKNOWN " + mForceHiding;
93 }
94 }
95
Craig Mautner918b53b2012-07-09 14:15:54 -070096 WindowAnimator(final WindowManagerService service) {
Craig Mautner764983d2012-03-22 11:37:36 -070097 mService = service;
Craig Mautner918b53b2012-07-09 14:15:54 -070098 mContext = service.mContext;
99 mPolicy = service.mPolicy;
Craig Mautner1caa3992012-06-22 09:46:48 -0700100
101 mAnimationRunnable = new Runnable() {
102 @Override
103 public void run() {
Craig Mautner96868332012-12-04 14:29:11 -0800104 synchronized (mService.mWindowMap) {
105 mService.mAnimationScheduled = false;
106 animateLocked();
Craig Mautner1caa3992012-06-22 09:46:48 -0700107 }
108 }
109 };
Craig Mautnerb47bbc32012-08-22 17:41:48 -0700110 }
Craig Mautner9e809442012-06-22 17:13:04 -0700111
Craig Mautnera91f9e22012-09-14 16:22:08 -0700112 void addDisplayLocked(final int displayId) {
Craig Mautnerac439e52012-09-21 08:58:34 -0700113 // Create the DisplayContentsAnimator object by retrieving it.
114 getDisplayContentsAnimatorLocked(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700115 if (displayId == Display.DEFAULT_DISPLAY) {
116 mInitialized = true;
117 }
118 }
119
120 void removeDisplayLocked(final int displayId) {
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700121 final DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
122 if (displayAnimator != null) {
123 if (displayAnimator.mWindowAnimationBackgroundSurface != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800124 displayAnimator.mWindowAnimationBackgroundSurface.destroySurface();
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700125 displayAnimator.mWindowAnimationBackgroundSurface = null;
126 }
127 if (displayAnimator.mScreenRotationAnimation != null) {
128 displayAnimator.mScreenRotationAnimation.kill();
129 displayAnimator.mScreenRotationAnimation = null;
130 }
131 if (displayAnimator.mDimAnimator != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800132 displayAnimator.mDimAnimator.destroySurface();
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700133 displayAnimator.mDimAnimator = null;
134 }
135 }
136
Craig Mautnera91f9e22012-09-14 16:22:08 -0700137 mDisplayContentsAnimators.delete(displayId);
Craig Mautner1caa3992012-06-22 09:46:48 -0700138 }
139
Craig Mautner96868332012-12-04 14:29:11 -0800140 AppWindowAnimator getWallpaperAppAnimator() {
141 return mService.mWallpaperTarget == null
142 ? null : mService.mWallpaperTarget.mAppToken == null
143 ? null : mService.mWallpaperTarget.mAppToken.mAppAnimator;
Craig Mautner711f90a2012-07-03 18:43:52 -0700144 }
145
Craig Mautner96868332012-12-04 14:29:11 -0800146 void hideWallpapersLocked(final WindowState w) {
147 final WindowState wallpaperTarget = mService.mWallpaperTarget;
148 final WindowState lowerWallpaperTarget = mService.mLowerWallpaperTarget;
149 final ArrayList<WindowToken> wallpaperTokens = mService.mWallpaperTokens;
Craig Mautner66f78d72012-12-04 16:46:50 -0800150
Dianne Hackborn98129732012-11-01 16:28:16 -0700151 if ((wallpaperTarget == w && lowerWallpaperTarget == null) || wallpaperTarget == null) {
152 final int numTokens = wallpaperTokens.size();
Craig Mautner918b53b2012-07-09 14:15:54 -0700153 for (int i = numTokens - 1; i >= 0; i--) {
Dianne Hackborn98129732012-11-01 16:28:16 -0700154 final WindowToken token = wallpaperTokens.get(i);
Craig Mautner918b53b2012-07-09 14:15:54 -0700155 final int numWindows = token.windows.size();
156 for (int j = numWindows - 1; j >= 0; j--) {
157 final WindowState wallpaper = token.windows.get(j);
Craig Mautnerb9836b92012-06-11 11:40:09 -0700158 final WindowStateAnimator winAnimator = wallpaper.mWinAnimator;
159 if (!winAnimator.mLastHidden) {
160 winAnimator.hide();
Craig Mautner507a2ee2012-06-13 08:39:38 -0700161 mService.dispatchWallpaperVisibility(wallpaper, false);
Craig Mautner76a71652012-09-03 23:23:58 -0700162 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
163 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnerb9836b92012-06-11 11:40:09 -0700164 }
165 }
Dianne Hackbornef03a7f2012-10-29 18:46:52 -0700166 if (WindowManagerService.DEBUG_WALLPAPER_LIGHT && !token.hidden) Slog.d(TAG,
Dianne Hackborn2ea9bae2012-11-02 18:43:48 -0700167 "Hiding wallpaper " + token + " from " + w
168 + " target=" + wallpaperTarget + " lower=" + lowerWallpaperTarget
169 + "\n" + Debug.getCallers(5, " "));
Craig Mautnerb9836b92012-06-11 11:40:09 -0700170 token.hidden = true;
Craig Mautner0afddcb2012-05-08 15:38:00 -0700171 }
Craig Mautner0afddcb2012-05-08 15:38:00 -0700172 }
173 }
174
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800175 private void updateAppWindowsLocked(int displayId) {
Craig Mautner764983d2012-03-22 11:37:36 -0700176 int i;
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800177 final DisplayContent displayContent = mService.getDisplayContentLocked(displayId);
Craig Mautner496bdbb2013-02-14 09:32:55 -0800178 AppTokenIterator iterator = displayContent.new AppTokenIterator();
179 while (iterator.hasNext()) {
180 final AppWindowAnimator appAnimator = iterator.next().mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700181 final boolean wasAnimating = appAnimator.animation != null
Craig Mautnerfbf378c2012-04-23 17:24:21 -0700182 && appAnimator.animation != AppWindowAnimator.sDummyAnimation;
Craig Mautner9339c402012-11-30 11:23:56 -0800183 if (appAnimator.stepAnimationLocked(mCurrentTime)) {
Craig Mautner764983d2012-03-22 11:37:36 -0700184 mAnimating = true;
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700185 } else if (wasAnimating) {
186 // stopped animating, do one more pass through the layout
Craig Mautner76a71652012-09-03 23:23:58 -0700187 setAppLayoutChanges(appAnimator, WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
188 "appToken " + appAnimator.mAppToken + " done");
Craig Mautner83339b42012-05-01 22:13:23 -0700189 if (WindowManagerService.DEBUG_ANIM) Slog.v(TAG,
190 "updateWindowsApps...: done animating " + appAnimator.mAppToken);
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700191 }
192 }
Craig Mautnera2c77052012-03-26 12:14:43 -0700193
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800194 final AppTokenList exitingAppTokens = displayContent.mExitingAppTokens;
195 final int NEAT = exitingAppTokens.size();
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700196 for (i=0; i<NEAT; i++) {
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800197 final AppWindowAnimator appAnimator = exitingAppTokens.get(i).mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700198 final boolean wasAnimating = appAnimator.animation != null
Craig Mautnerfbf378c2012-04-23 17:24:21 -0700199 && appAnimator.animation != AppWindowAnimator.sDummyAnimation;
Craig Mautner9339c402012-11-30 11:23:56 -0800200 if (appAnimator.stepAnimationLocked(mCurrentTime)) {
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700201 mAnimating = true;
202 } else if (wasAnimating) {
203 // stopped animating, do one more pass through the layout
Craig Mautner76a71652012-09-03 23:23:58 -0700204 setAppLayoutChanges(appAnimator, WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
205 "exiting appToken " + appAnimator.mAppToken + " done");
Craig Mautner83339b42012-05-01 22:13:23 -0700206 if (WindowManagerService.DEBUG_ANIM) Slog.v(TAG,
207 "updateWindowsApps...: done animating exiting " + appAnimator.mAppToken);
Craig Mautner764983d2012-03-22 11:37:36 -0700208 }
209 }
Craig Mautner764983d2012-03-22 11:37:36 -0700210 }
211
Craig Mautnera91f9e22012-09-14 16:22:08 -0700212 private void updateWindowsLocked(final int displayId) {
Craig Mautner6fbda632012-07-03 09:26:39 -0700213 ++mAnimTransactionSequence;
Craig Mautner764983d2012-03-22 11:37:36 -0700214
Craig Mautner96868332012-12-04 14:29:11 -0800215 final WindowList windows = mService.getWindowListLocked(displayId);
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700216 ArrayList<WindowStateAnimator> unForceHiding = null;
217 boolean wallpaperInUnForceHiding = false;
Craig Mautner178af592012-09-17 10:37:29 -0700218 mForceHiding = KEYGUARD_NOT_SHOWN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700219
Craig Mautner96868332012-12-04 14:29:11 -0800220 for (int i = windows.size() - 1; i >= 0; i--) {
221 WindowState win = windows.get(i);
222 WindowStateAnimator winAnimator = win.mWinAnimator;
Craig Mautnerbec53f72012-04-05 11:49:05 -0700223 final int flags = winAnimator.mAttrFlags;
Craig Mautner764983d2012-03-22 11:37:36 -0700224
Craig Mautnerc2f9be02012-03-27 17:32:29 -0700225 if (winAnimator.mSurface != null) {
Craig Mautnera2c77052012-03-26 12:14:43 -0700226 final boolean wasAnimating = winAnimator.mWasAnimating;
227 final boolean nowAnimating = winAnimator.stepAnimationLocked(mCurrentTime);
Craig Mautner764983d2012-03-22 11:37:36 -0700228
229 if (WindowManagerService.DEBUG_WALLPAPER) {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700230 Slog.v(TAG, win + ": wasAnimating=" + wasAnimating +
Craig Mautner764983d2012-03-22 11:37:36 -0700231 ", nowAnimating=" + nowAnimating);
232 }
233
Craig Mautner96868332012-12-04 14:29:11 -0800234 if (wasAnimating && !winAnimator.mAnimating && mService.mWallpaperTarget == win) {
Craig Mautnera608b882012-03-30 13:03:49 -0700235 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
Craig Mautner76a71652012-09-03 23:23:58 -0700236 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
237 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700238 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700239 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 2",
Craig Mautner66f78d72012-12-04 16:46:50 -0800240 getPendingLayoutChanges(Display.DEFAULT_DISPLAY));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700241 }
Craig Mautner764983d2012-03-22 11:37:36 -0700242 }
243
Craig Mautnerbec53f72012-04-05 11:49:05 -0700244 if (mPolicy.doesForceHide(win, win.mAttrs)) {
Craig Mautner764983d2012-03-22 11:37:36 -0700245 if (!wasAnimating && nowAnimating) {
Craig Mautner83339b42012-05-01 22:13:23 -0700246 if (WindowManagerService.DEBUG_ANIM ||
247 WindowManagerService.DEBUG_VISIBILITY) Slog.v(TAG,
248 "Animation started that could impact force hide: " + win);
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700249 mBulkUpdateParams |= SET_FORCE_HIDING_CHANGED;
Craig Mautner76a71652012-09-03 23:23:58 -0700250 setPendingLayoutChanges(displayId,
251 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700252 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700253 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 3",
Craig Mautner66f78d72012-12-04 16:46:50 -0800254 getPendingLayoutChanges(displayId));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700255 }
Craig Mautner764983d2012-03-22 11:37:36 -0700256 mService.mFocusMayChange = true;
Dianne Hackbornac920872012-05-22 11:49:49 -0700257 }
Craig Mautner4bf18a72012-07-10 14:08:16 -0700258 if (win.isReadyForDisplay()) {
259 if (nowAnimating) {
260 if (winAnimator.mAnimationIsEntrance) {
Craig Mautner178af592012-09-17 10:37:29 -0700261 mForceHiding = KEYGUARD_ANIMATING_IN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700262 } else {
Craig Mautner178af592012-09-17 10:37:29 -0700263 mForceHiding = KEYGUARD_ANIMATING_OUT;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700264 }
265 } else {
Craig Mautner178af592012-09-17 10:37:29 -0700266 mForceHiding = KEYGUARD_SHOWN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700267 }
Craig Mautner764983d2012-03-22 11:37:36 -0700268 }
Dianne Hackbornac920872012-05-22 11:49:49 -0700269 if (WindowManagerService.DEBUG_VISIBILITY) Slog.v(TAG,
Craig Mautner178af592012-09-17 10:37:29 -0700270 "Force hide " + mForceHiding
Dianne Hackbornac920872012-05-22 11:49:49 -0700271 + " hasSurface=" + win.mHasSurface
272 + " policyVis=" + win.mPolicyVisibility
273 + " destroying=" + win.mDestroying
274 + " attHidden=" + win.mAttachedHidden
275 + " vis=" + win.mViewVisibility
276 + " hidden=" + win.mRootToken.hidden
277 + " anim=" + win.mWinAnimator.mAnimation);
Craig Mautnerbec53f72012-04-05 11:49:05 -0700278 } else if (mPolicy.canBeForceHidden(win, win.mAttrs)) {
Craig Mautner4bf18a72012-07-10 14:08:16 -0700279 final boolean hideWhenLocked =
280 (winAnimator.mAttrFlags & FLAG_SHOW_WHEN_LOCKED) == 0;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700281 final boolean changed;
Craig Mautner178af592012-09-17 10:37:29 -0700282 if (((mForceHiding == KEYGUARD_ANIMATING_IN)
Craig Mautner4bf18a72012-07-10 14:08:16 -0700283 && (!winAnimator.isAnimating() || hideWhenLocked))
Craig Mautner178af592012-09-17 10:37:29 -0700284 || ((mForceHiding == KEYGUARD_SHOWN) && hideWhenLocked)) {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700285 changed = win.hideLw(false, false);
Craig Mautner764983d2012-03-22 11:37:36 -0700286 if (WindowManagerService.DEBUG_VISIBILITY && changed) Slog.v(TAG,
Craig Mautnerbec53f72012-04-05 11:49:05 -0700287 "Now policy hidden: " + win);
Craig Mautner764983d2012-03-22 11:37:36 -0700288 } else {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700289 changed = win.showLw(false, false);
Craig Mautner764983d2012-03-22 11:37:36 -0700290 if (WindowManagerService.DEBUG_VISIBILITY && changed) Slog.v(TAG,
Craig Mautnerbec53f72012-04-05 11:49:05 -0700291 "Now policy shown: " + win);
Craig Mautner764983d2012-03-22 11:37:36 -0700292 if (changed) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700293 if ((mBulkUpdateParams & SET_FORCE_HIDING_CHANGED) != 0
Craig Mautnerbec53f72012-04-05 11:49:05 -0700294 && win.isVisibleNow() /*w.isReadyForDisplay()*/) {
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700295 if (unForceHiding == null) {
296 unForceHiding = new ArrayList<WindowStateAnimator>();
297 }
298 unForceHiding.add(winAnimator);
Craig Mautner01cd0e72012-06-18 10:19:11 -0700299 if ((flags & FLAG_SHOW_WALLPAPER) != 0) {
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700300 wallpaperInUnForceHiding = true;
Craig Mautner764983d2012-03-22 11:37:36 -0700301 }
302 }
Craig Mautnerbec53f72012-04-05 11:49:05 -0700303 if (mCurrentFocus == null || mCurrentFocus.mLayer < win.mLayer) {
Craig Mautner764983d2012-03-22 11:37:36 -0700304 // We are showing on to of the current
305 // focus, so re-evaluate focus to make
306 // sure it is correct.
307 mService.mFocusMayChange = true;
308 }
309 }
310 }
Craig Mautner01cd0e72012-06-18 10:19:11 -0700311 if (changed && (flags & FLAG_SHOW_WALLPAPER) != 0) {
Craig Mautnera608b882012-03-30 13:03:49 -0700312 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
Craig Mautner76a71652012-09-03 23:23:58 -0700313 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
314 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700315 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700316 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 4",
Craig Mautner66f78d72012-12-04 16:46:50 -0800317 getPendingLayoutChanges(Display.DEFAULT_DISPLAY));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700318 }
Craig Mautner764983d2012-03-22 11:37:36 -0700319 }
320 }
321 }
322
Craig Mautnerbec53f72012-04-05 11:49:05 -0700323 final AppWindowToken atoken = win.mAppToken;
Craig Mautner6fbda632012-07-03 09:26:39 -0700324 if (winAnimator.mDrawState == WindowStateAnimator.READY_TO_SHOW) {
325 if (atoken == null || atoken.allDrawn) {
326 if (winAnimator.performShowLocked()) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800327 setPendingLayoutChanges(displayId,
Craig Mautner76a71652012-09-03 23:23:58 -0700328 WindowManagerPolicy.FINISH_LAYOUT_REDO_ANIM);
Craig Mautner6fbda632012-07-03 09:26:39 -0700329 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
330 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 5",
Craig Mautner66f78d72012-12-04 16:46:50 -0800331 getPendingLayoutChanges(displayId));
Craig Mautner764983d2012-03-22 11:37:36 -0700332 }
333 }
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700334 }
Craig Mautner764983d2012-03-22 11:37:36 -0700335 }
Craig Mautner322e4032012-07-13 13:35:20 -0700336 final AppWindowAnimator appAnimator = winAnimator.mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700337 if (appAnimator != null && appAnimator.thumbnail != null) {
Craig Mautner6fbda632012-07-03 09:26:39 -0700338 if (appAnimator.thumbnailTransactionSeq != mAnimTransactionSequence) {
339 appAnimator.thumbnailTransactionSeq = mAnimTransactionSequence;
Craig Mautner59431632012-04-04 11:56:44 -0700340 appAnimator.thumbnailLayer = 0;
Dianne Hackborn8078d8c2012-03-20 11:11:26 -0700341 }
Craig Mautner59431632012-04-04 11:56:44 -0700342 if (appAnimator.thumbnailLayer < winAnimator.mAnimLayer) {
343 appAnimator.thumbnailLayer = winAnimator.mAnimLayer;
Dianne Hackborn8078d8c2012-03-20 11:11:26 -0700344 }
345 }
Craig Mautner764983d2012-03-22 11:37:36 -0700346 } // end forall windows
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700347
Craig Mautner078ea0a2012-06-25 11:04:29 -0700348 // If we have windows that are being show due to them no longer
349 // being force-hidden, apply the appropriate animation to them.
350 if (unForceHiding != null) {
351 for (int i=unForceHiding.size()-1; i>=0; i--) {
352 Animation a = mPolicy.createForceHideEnterAnimation(wallpaperInUnForceHiding);
353 if (a != null) {
354 final WindowStateAnimator winAnimator = unForceHiding.get(i);
355 winAnimator.setAnimation(a);
356 winAnimator.mAnimationIsEntrance = true;
357 }
358 }
359 }
360 }
361
Craig Mautnera91f9e22012-09-14 16:22:08 -0700362 private void updateWallpaperLocked(int displayId) {
363 final DisplayContentsAnimator displayAnimator =
364 getDisplayContentsAnimatorLocked(displayId);
Craig Mautner96868332012-12-04 14:29:11 -0800365 final WindowList windows = mService.getWindowListLocked(displayId);
Craig Mautner078ea0a2012-06-25 11:04:29 -0700366 WindowStateAnimator windowAnimationBackground = null;
367 int windowAnimationBackgroundColor = 0;
368 WindowState detachedWallpaper = null;
369
Craig Mautner96868332012-12-04 14:29:11 -0800370 for (int i = windows.size() - 1; i >= 0; i--) {
371 final WindowState win = windows.get(i);
372 WindowStateAnimator winAnimator = win.mWinAnimator;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700373 if (winAnimator.mSurface == null) {
374 continue;
375 }
376
377 final int flags = winAnimator.mAttrFlags;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700378
379 // If this window is animating, make a note that we have
380 // an animating window and take care of a request to run
381 // a detached wallpaper animation.
382 if (winAnimator.mAnimating) {
383 if (winAnimator.mAnimation != null) {
384 if ((flags & FLAG_SHOW_WALLPAPER) != 0
385 && winAnimator.mAnimation.getDetachWallpaper()) {
386 detachedWallpaper = win;
387 }
388 final int backgroundColor = winAnimator.mAnimation.getBackgroundColor();
389 if (backgroundColor != 0) {
390 if (windowAnimationBackground == null || (winAnimator.mAnimLayer <
391 windowAnimationBackground.mAnimLayer)) {
392 windowAnimationBackground = winAnimator;
393 windowAnimationBackgroundColor = backgroundColor;
394 }
395 }
396 }
397 mAnimating = true;
398 }
399
400 // If this window's app token is running a detached wallpaper
401 // animation, make a note so we can ensure the wallpaper is
402 // displayed behind it.
Craig Mautner322e4032012-07-13 13:35:20 -0700403 final AppWindowAnimator appAnimator = winAnimator.mAppAnimator;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700404 if (appAnimator != null && appAnimator.animation != null
405 && appAnimator.animating) {
406 if ((flags & FLAG_SHOW_WALLPAPER) != 0
407 && appAnimator.animation.getDetachWallpaper()) {
408 detachedWallpaper = win;
409 }
410
411 final int backgroundColor = appAnimator.animation.getBackgroundColor();
412 if (backgroundColor != 0) {
413 if (windowAnimationBackground == null || (winAnimator.mAnimLayer <
414 windowAnimationBackground.mAnimLayer)) {
415 windowAnimationBackground = winAnimator;
416 windowAnimationBackgroundColor = backgroundColor;
417 }
418 }
419 }
420 } // end forall windows
421
Craig Mautner9e809442012-06-22 17:13:04 -0700422 if (mWindowDetachedWallpaper != detachedWallpaper) {
423 if (WindowManagerService.DEBUG_WALLPAPER) Slog.v(TAG,
424 "Detached wallpaper changed from " + mWindowDetachedWallpaper
425 + " to " + detachedWallpaper);
426 mWindowDetachedWallpaper = detachedWallpaper;
427 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
428 }
429
430 if (windowAnimationBackgroundColor != 0) {
431 // If the window that wants black is the current wallpaper
432 // target, then the black goes *below* the wallpaper so we
433 // don't cause the wallpaper to suddenly disappear.
434 int animLayer = windowAnimationBackground.mAnimLayer;
435 WindowState win = windowAnimationBackground.mWin;
Craig Mautner96868332012-12-04 14:29:11 -0800436 if (mService.mWallpaperTarget == win || mService.mLowerWallpaperTarget == win
437 || mService.mUpperWallpaperTarget == win) {
438 final int N = windows.size();
Craig Mautner9e809442012-06-22 17:13:04 -0700439 for (int i = 0; i < N; i++) {
Craig Mautner96868332012-12-04 14:29:11 -0800440 WindowStateAnimator winAnimator = windows.get(i).mWinAnimator;
Craig Mautner918b53b2012-07-09 14:15:54 -0700441 if (winAnimator.mIsWallpaper) {
Craig Mautner9e809442012-06-22 17:13:04 -0700442 animLayer = winAnimator.mAnimLayer;
443 break;
444 }
445 }
446 }
447
Craig Mautner1420b932012-12-28 17:14:38 -0800448 displayAnimator.mWindowAnimationBackgroundSurface.show(
449 animLayer - WindowManagerService.LAYER_OFFSET_DIM,
450 ((windowAnimationBackgroundColor >> 24) & 0xff) / 255f, 0);
Craig Mautner9e809442012-06-22 17:13:04 -0700451 } else {
Craig Mautner1420b932012-12-28 17:14:38 -0800452 displayAnimator.mWindowAnimationBackgroundSurface.hide();
Craig Mautner9e809442012-06-22 17:13:04 -0700453 }
Craig Mautner764983d2012-03-22 11:37:36 -0700454 }
455
Craig Mautner9339c402012-11-30 11:23:56 -0800456 /** See if any windows have been drawn, so they (and others associated with them) can now be
457 * shown. */
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800458 private void testTokenMayBeDrawnLocked(int displayId) {
Craig Mautner96868332012-12-04 14:29:11 -0800459 // See if any windows have been drawn, so they (and others
460 // associated with them) can now be shown.
Craig Mautner496bdbb2013-02-14 09:32:55 -0800461 AppTokenIterator iterator = mService.getDisplayContentLocked(displayId).new
462 AppTokenIterator();
463 while (iterator.hasNext()) {
464 AppWindowToken wtoken = iterator.next();
Craig Mautner96868332012-12-04 14:29:11 -0800465 AppWindowAnimator appAnimator = wtoken.mAppAnimator;
Craig Mautner6fbda632012-07-03 09:26:39 -0700466 final boolean allDrawn = wtoken.allDrawn;
Craig Mautner322e4032012-07-13 13:35:20 -0700467 if (allDrawn != appAnimator.allDrawn) {
468 appAnimator.allDrawn = allDrawn;
Craig Mautner6fbda632012-07-03 09:26:39 -0700469 if (allDrawn) {
470 // The token has now changed state to having all
471 // windows shown... what to do, what to do?
Craig Mautner322e4032012-07-13 13:35:20 -0700472 if (appAnimator.freezingScreen) {
473 appAnimator.showAllWindowsLocked();
Craig Mautner6fbda632012-07-03 09:26:39 -0700474 mService.unsetAppFreezingScreenLocked(wtoken, false, true);
475 if (WindowManagerService.DEBUG_ORIENTATION) Slog.i(TAG,
476 "Setting mOrientationChangeComplete=true because wtoken "
477 + wtoken + " numInteresting=" + wtoken.numInterestingWindows
478 + " numDrawn=" + wtoken.numDrawnWindows);
479 // This will set mOrientationChangeComplete and cause a pass through layout.
Craig Mautner76a71652012-09-03 23:23:58 -0700480 setAppLayoutChanges(appAnimator,
481 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
482 "testTokenMayBeDrawnLocked: freezingScreen");
Craig Mautner6fbda632012-07-03 09:26:39 -0700483 } else {
Craig Mautner76a71652012-09-03 23:23:58 -0700484 setAppLayoutChanges(appAnimator,
485 WindowManagerPolicy.FINISH_LAYOUT_REDO_ANIM,
486 "testTokenMayBeDrawnLocked");
Craig Mautner66f78d72012-12-04 16:46:50 -0800487
Craig Mautner6fbda632012-07-03 09:26:39 -0700488 // We can now show all of the drawn windows!
489 if (!mService.mOpeningApps.contains(wtoken)) {
Craig Mautner322e4032012-07-13 13:35:20 -0700490 mAnimating |= appAnimator.showAllWindowsLocked();
Craig Mautner6fbda632012-07-03 09:26:39 -0700491 }
Craig Mautner764983d2012-03-22 11:37:36 -0700492 }
493 }
494 }
495 }
496 }
497
Craig Mautnera91f9e22012-09-14 16:22:08 -0700498 private void performAnimationsLocked(final int displayId) {
499 updateWindowsLocked(displayId);
500 updateWallpaperLocked(displayId);
Craig Mautner764983d2012-03-22 11:37:36 -0700501 }
502
Craig Mautner1420b932012-12-28 17:14:38 -0800503 private long getDimBehindFadeDuration(long duration) {
504 TypedValue tv = new TypedValue();
505 mContext.getResources().getValue(
506 com.android.internal.R.fraction.config_dimBehindFadeDuration, tv, true);
507 if (tv.type == TypedValue.TYPE_FRACTION) {
508 duration = (long)tv.getFraction(duration, duration);
509 } else if (tv.type >= TypedValue.TYPE_FIRST_INT && tv.type <= TypedValue.TYPE_LAST_INT) {
510 duration = tv.data;
511 }
512 return duration;
513 }
514
515 /** Locked on mService.mWindowMap. */
Craig Mautner1caa3992012-06-22 09:46:48 -0700516 private void animateLocked() {
Craig Mautnerb47bbc32012-08-22 17:41:48 -0700517 if (!mInitialized) {
518 return;
519 }
Craig Mautner59c00972012-07-30 12:10:24 -0700520
Craig Mautner764983d2012-03-22 11:37:36 -0700521 mCurrentTime = SystemClock.uptimeMillis();
Craig Mautner2639da52012-07-09 09:39:06 -0700522 mBulkUpdateParams = SET_ORIENTATION_CHANGE_COMPLETE;
Chet Haase198e5642012-05-10 09:55:15 -0700523 boolean wasAnimating = mAnimating;
Craig Mautner7d8df392012-04-06 15:26:23 -0700524 mAnimating = false;
525 if (WindowManagerService.DEBUG_WINDOW_TRACE) {
526 Slog.i(TAG, "!!! animate: entry time=" + mCurrentTime);
527 }
Craig Mautner764983d2012-03-22 11:37:36 -0700528
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700529 if (WindowManagerService.SHOW_TRANSACTIONS) Slog.i(
530 TAG, ">>> OPEN TRANSACTION animateLocked");
Craig Mautner764983d2012-03-22 11:37:36 -0700531 Surface.openTransaction();
Jamie Gennisb6ce6e42012-10-15 19:14:58 -0700532 Surface.setAnimationTransaction();
Craig Mautner764983d2012-03-22 11:37:36 -0700533 try {
Craig Mautnera91f9e22012-09-14 16:22:08 -0700534 final int numDisplays = mDisplayContentsAnimators.size();
535 for (int i = 0; i < numDisplays; i++) {
536 final int displayId = mDisplayContentsAnimators.keyAt(i);
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800537 updateAppWindowsLocked(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700538 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
539
540 final ScreenRotationAnimation screenRotationAnimation =
541 displayAnimator.mScreenRotationAnimation;
542 if (screenRotationAnimation != null && screenRotationAnimation.isAnimating()) {
543 if (screenRotationAnimation.stepAnimationLocked(mCurrentTime)) {
544 mAnimating = true;
545 } else {
546 mBulkUpdateParams |= SET_UPDATE_ROTATION;
547 screenRotationAnimation.kill();
548 displayAnimator.mScreenRotationAnimation = null;
549 }
550 }
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700551
552 // Update animations of all applications, including those
553 // associated with exiting/removed apps
Craig Mautnera91f9e22012-09-14 16:22:08 -0700554 performAnimationsLocked(displayId);
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700555
Craig Mautner96868332012-12-04 14:29:11 -0800556 final WindowList windows = mService.getWindowListLocked(displayId);
557 final int N = windows.size();
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700558 for (int j = 0; j < N; j++) {
Craig Mautner96868332012-12-04 14:29:11 -0800559 windows.get(j).mWinAnimator.prepareSurfaceLocked(true);
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700560 }
561 }
562
Craig Mautnera91f9e22012-09-14 16:22:08 -0700563 for (int i = 0; i < numDisplays; i++) {
564 final int displayId = mDisplayContentsAnimators.keyAt(i);
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800565
566 testTokenMayBeDrawnLocked(displayId);
567
Craig Mautnera91f9e22012-09-14 16:22:08 -0700568 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
Craig Mautner764983d2012-03-22 11:37:36 -0700569
Craig Mautnera91f9e22012-09-14 16:22:08 -0700570 final ScreenRotationAnimation screenRotationAnimation =
571 displayAnimator.mScreenRotationAnimation;
572 if (screenRotationAnimation != null) {
573 screenRotationAnimation.updateSurfacesInTransaction();
574 }
575
Craig Mautner1420b932012-12-28 17:14:38 -0800576 final DimLayer dimAnimator = displayAnimator.mDimAnimator;
577 final WindowStateAnimator winAnimator = displayAnimator.mDimWinAnimator;
Craig Mautner13131e72013-01-11 11:03:33 -0800578 final int dimLayer;
Craig Mautner1420b932012-12-28 17:14:38 -0800579 final float dimAmount;
580 if (winAnimator == null) {
Craig Mautner13131e72013-01-11 11:03:33 -0800581 dimLayer = dimAnimator.getLayer();
Craig Mautner1420b932012-12-28 17:14:38 -0800582 dimAmount = 0;
583 } else {
Craig Mautner13131e72013-01-11 11:03:33 -0800584 dimLayer = winAnimator.mAnimLayer - WindowManagerService.LAYER_OFFSET_DIM;
Craig Mautner1420b932012-12-28 17:14:38 -0800585 dimAmount = winAnimator.mWin.mAttrs.dimAmount;
Craig Mautnera91f9e22012-09-14 16:22:08 -0700586 }
Craig Mautner1420b932012-12-28 17:14:38 -0800587 final float targetAlpha = dimAnimator.getTargetAlpha();
588 if (targetAlpha != dimAmount) {
589 if (winAnimator == null) {
590 dimAnimator.hide(DEFAULT_DIM_DURATION);
591 } else {
592 long duration = (winAnimator.mAnimating && winAnimator.mAnimation != null)
593 ? winAnimator.mAnimation.computeDurationHint()
594 : DEFAULT_DIM_DURATION;
595 if (targetAlpha > dimAmount) {
596 duration = getDimBehindFadeDuration(duration);
597 }
Craig Mautner13131e72013-01-11 11:03:33 -0800598 dimAnimator.show(dimLayer, dimAmount, duration);
Craig Mautner1420b932012-12-28 17:14:38 -0800599 }
Craig Mautner13131e72013-01-11 11:03:33 -0800600 } else if (dimAnimator.getLayer() != dimLayer) {
601 dimAnimator.setLayer(dimLayer);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700602 }
Craig Mautner1420b932012-12-28 17:14:38 -0800603 if (dimAnimator.isAnimating()) {
604 if (!mService.okToDisplay()) {
605 // Jump to the end of the animation.
606 dimAnimator.show();
607 } else {
608 mAnimating |= dimAnimator.stepAnimation();
609 }
610 }
611
Svetoslav Ganov545252f2012-12-10 18:29:24 -0800612 //TODO (multidisplay): Magnification is supported only for the default display.
613 if (mService.mDisplayMagnifier != null && displayId == Display.DEFAULT_DISPLAY) {
614 mService.mDisplayMagnifier.drawMagnifiedRegionBorderIfNeededLocked();
615 }
Craig Mautner764983d2012-03-22 11:37:36 -0700616 }
617
Craig Mautner7358fbf2012-04-12 21:06:33 -0700618 if (mService.mWatermark != null) {
619 mService.mWatermark.drawIfNeeded();
620 }
Craig Mautner764983d2012-03-22 11:37:36 -0700621 } catch (RuntimeException e) {
622 Log.wtf(TAG, "Unhandled exception in Window Manager", e);
623 } finally {
624 Surface.closeTransaction();
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700625 if (WindowManagerService.SHOW_TRANSACTIONS) Slog.i(
626 TAG, "<<< CLOSE TRANSACTION animateLocked");
627 }
628
Craig Mautner66f78d72012-12-04 16:46:50 -0800629 boolean hasPendingLayoutChanges = false;
630 DisplayContentsIterator iterator = mService.new DisplayContentsIterator();
631 while (iterator.hasNext()) {
632 final DisplayContent displayContent = iterator.next();
633 final int pendingChanges = getPendingLayoutChanges(displayContent.getDisplayId());
634 if ((pendingChanges & WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER) != 0) {
Craig Mautner96868332012-12-04 14:29:11 -0800635 mBulkUpdateParams |= SET_WALLPAPER_ACTION_PENDING;
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700636 }
Craig Mautner66f78d72012-12-04 16:46:50 -0800637 if (pendingChanges != 0) {
638 hasPendingLayoutChanges = true;
639 }
Craig Mautner764983d2012-03-22 11:37:36 -0700640 }
Craig Mautnerc2f9be02012-03-27 17:32:29 -0700641
Craig Mautner66f78d72012-12-04 16:46:50 -0800642 boolean doRequest = false;
643 if (mBulkUpdateParams != 0) {
644 doRequest = mService.copyAnimToLayoutParamsLocked();
645 }
646
647 if (hasPendingLayoutChanges || doRequest) {
648 mService.requestTraversalLocked();
Craig Mautner01cd0e72012-06-18 10:19:11 -0700649 }
Craig Mautner7d8df392012-04-06 15:26:23 -0700650
651 if (mAnimating) {
Craig Mautner96868332012-12-04 14:29:11 -0800652 mService.scheduleAnimationLocked();
Chet Haase198e5642012-05-10 09:55:15 -0700653 } else if (wasAnimating) {
654 mService.requestTraversalLocked();
Craig Mautner7d8df392012-04-06 15:26:23 -0700655 }
656 if (WindowManagerService.DEBUG_WINDOW_TRACE) {
657 Slog.i(TAG, "!!! animate: exit mAnimating=" + mAnimating
658 + " mBulkUpdateParams=" + Integer.toHexString(mBulkUpdateParams)
Craig Mautner76a71652012-09-03 23:23:58 -0700659 + " mPendingLayoutChanges(DEFAULT_DISPLAY)="
Craig Mautner66f78d72012-12-04 16:46:50 -0800660 + Integer.toHexString(getPendingLayoutChanges(Display.DEFAULT_DISPLAY)));
Craig Mautner7d8df392012-04-06 15:26:23 -0700661 }
Craig Mautner764983d2012-03-22 11:37:36 -0700662 }
663
664 WindowState mCurrentFocus;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700665 void setCurrentFocus(final WindowState currentFocus) {
Craig Mautner764983d2012-03-22 11:37:36 -0700666 mCurrentFocus = currentFocus;
667 }
668
Craig Mautnera91f9e22012-09-14 16:22:08 -0700669 boolean isDimmingLocked(int displayId) {
Craig Mautner1420b932012-12-28 17:14:38 -0800670 return getDisplayContentsAnimatorLocked(displayId).mDimAnimator.isDimming();
Craig Mautnerf8d4fbb2012-04-11 09:25:53 -0700671 }
672
Craig Mautnera91f9e22012-09-14 16:22:08 -0700673 boolean isDimmingLocked(final WindowStateAnimator winAnimator) {
Craig Mautner1420b932012-12-28 17:14:38 -0800674 final int displayId = winAnimator.mWin.getDisplayId();
675 DisplayContentsAnimator displayAnimator =
676 getDisplayContentsAnimatorLocked(displayId);
677 if (displayAnimator != null) {
678 return displayAnimator.mDimWinAnimator == winAnimator
679 && displayAnimator.mDimAnimator.isDimming();
680 }
681 return false;
Craig Mautneracafd192012-05-10 10:41:02 -0700682 }
683
Dianne Hackborn529e7442012-11-01 14:22:28 -0700684 static String bulkUpdateParamsToString(int bulkUpdateParams) {
685 StringBuilder builder = new StringBuilder(128);
686 if ((bulkUpdateParams & LayoutFields.SET_UPDATE_ROTATION) != 0) {
687 builder.append(" UPDATE_ROTATION");
688 }
689 if ((bulkUpdateParams & LayoutFields.SET_WALLPAPER_MAY_CHANGE) != 0) {
690 builder.append(" WALLPAPER_MAY_CHANGE");
691 }
692 if ((bulkUpdateParams & LayoutFields.SET_FORCE_HIDING_CHANGED) != 0) {
693 builder.append(" FORCE_HIDING_CHANGED");
694 }
695 if ((bulkUpdateParams & LayoutFields.SET_ORIENTATION_CHANGE_COMPLETE) != 0) {
696 builder.append(" ORIENTATION_CHANGE_COMPLETE");
697 }
698 if ((bulkUpdateParams & LayoutFields.SET_TURN_ON_SCREEN) != 0) {
699 builder.append(" TURN_ON_SCREEN");
700 }
701 return builder.toString();
702 }
703
Craig Mautnera91f9e22012-09-14 16:22:08 -0700704 public void dumpLocked(PrintWriter pw, String prefix, boolean dumpAll) {
Dianne Hackborn529e7442012-11-01 14:22:28 -0700705 final String subPrefix = " " + prefix;
706 final String subSubPrefix = " " + subPrefix;
707
Dianne Hackborn529e7442012-11-01 14:22:28 -0700708 for (int i = 0; i < mDisplayContentsAnimators.size(); i++) {
709 pw.print(prefix); pw.print("DisplayContentsAnimator #");
710 pw.print(mDisplayContentsAnimators.keyAt(i));
711 pw.println(":");
712 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
Craig Mautner96868332012-12-04 14:29:11 -0800713 final WindowList windows =
714 mService.getWindowListLocked(mDisplayContentsAnimators.keyAt(i));
715 final int N = windows.size();
716 for (int j = 0; j < N; j++) {
717 WindowStateAnimator wanim = windows.get(j).mWinAnimator;
Dianne Hackborn529e7442012-11-01 14:22:28 -0700718 pw.print(subPrefix); pw.print("Window #"); pw.print(j);
719 pw.print(": "); pw.println(wanim);
720 }
721 if (displayAnimator.mWindowAnimationBackgroundSurface != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800722 if (dumpAll || displayAnimator.mWindowAnimationBackgroundSurface.isDimming()) {
Dianne Hackborn529e7442012-11-01 14:22:28 -0700723 pw.print(subPrefix); pw.println("mWindowAnimationBackgroundSurface:");
Craig Mautnera91f9e22012-09-14 16:22:08 -0700724 displayAnimator.mWindowAnimationBackgroundSurface.printTo(subSubPrefix, pw);
725 }
Craig Mautner6fbda632012-07-03 09:26:39 -0700726 }
Craig Mautner1420b932012-12-28 17:14:38 -0800727 if (dumpAll || displayAnimator.mDimAnimator.isDimming()) {
728 pw.print(subPrefix); pw.println("mDimAnimator:");
729 displayAnimator.mDimAnimator.printTo(subSubPrefix, pw);
730 pw.print(subPrefix); pw.print("mDimWinAnimator=");
731 pw.println(displayAnimator.mDimWinAnimator);
Dianne Hackborn529e7442012-11-01 14:22:28 -0700732 }
733 if (displayAnimator.mScreenRotationAnimation != null) {
734 pw.print(subPrefix); pw.println("mScreenRotationAnimation:");
735 displayAnimator.mScreenRotationAnimation.printTo(subSubPrefix, pw);
736 } else if (dumpAll) {
737 pw.print(subPrefix); pw.println("no ScreenRotationAnimation ");
738 }
739 }
740
741 pw.println();
742
743 if (dumpAll) {
744 pw.print(prefix); pw.print("mAnimTransactionSequence=");
745 pw.print(mAnimTransactionSequence);
746 pw.print(" mForceHiding="); pw.println(forceHidingToString());
747 pw.print(prefix); pw.print("mCurrentTime=");
748 pw.println(TimeUtils.formatUptime(mCurrentTime));
Dianne Hackborn529e7442012-11-01 14:22:28 -0700749 }
750 if (mBulkUpdateParams != 0) {
751 pw.print(prefix); pw.print("mBulkUpdateParams=0x");
752 pw.print(Integer.toHexString(mBulkUpdateParams));
753 pw.println(bulkUpdateParamsToString(mBulkUpdateParams));
754 }
Dianne Hackborn529e7442012-11-01 14:22:28 -0700755 if (mWindowDetachedWallpaper != null) {
756 pw.print(prefix); pw.print("mWindowDetachedWallpaper=");
757 pw.println(mWindowDetachedWallpaper);
758 }
Dianne Hackborn529e7442012-11-01 14:22:28 -0700759 if (mUniverseBackground != null) {
760 pw.print(prefix); pw.print("mUniverseBackground="); pw.print(mUniverseBackground);
761 pw.print(" mAboveUniverseLayer="); pw.println(mAboveUniverseLayer);
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700762 }
Craig Mautnere7ae2502012-03-26 17:11:19 -0700763 }
Craig Mautnerbec53f72012-04-05 11:49:05 -0700764
Craig Mautner66f78d72012-12-04 16:46:50 -0800765 int getPendingLayoutChanges(final int displayId) {
766 return mService.getDisplayContentLocked(displayId).pendingLayoutChanges;
767 }
768
Craig Mautner76a71652012-09-03 23:23:58 -0700769 void setPendingLayoutChanges(final int displayId, final int changes) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800770 mService.getDisplayContentLocked(displayId).pendingLayoutChanges |= changes;
Craig Mautner76a71652012-09-03 23:23:58 -0700771 }
772
773 void setAppLayoutChanges(final AppWindowAnimator appAnimator, final int changes, String s) {
774 // Used to track which displays layout changes have been done.
775 SparseIntArray displays = new SparseIntArray();
Craig Mautner96868332012-12-04 14:29:11 -0800776 WindowList windows = appAnimator.mAppToken.allAppWindows;
777 for (int i = windows.size() - 1; i >= 0; i--) {
778 final int displayId = windows.get(i).getDisplayId();
Craig Mautner76a71652012-09-03 23:23:58 -0700779 if (displays.indexOfKey(displayId) < 0) {
780 setPendingLayoutChanges(displayId, changes);
781 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800782 mService.debugLayoutRepeats(s, getPendingLayoutChanges(displayId));
Craig Mautner76a71652012-09-03 23:23:58 -0700783 }
784 // Keep from processing this display again.
785 displays.put(displayId, changes);
786 }
787 }
Craig Mautner4d7349b2012-04-20 14:52:47 -0700788 }
Craig Mautnera91f9e22012-09-14 16:22:08 -0700789
Craig Mautner1420b932012-12-28 17:14:38 -0800790 void setDimWinAnimatorLocked(int displayId, WindowStateAnimator newWinAnimator) {
Craig Mautner96868332012-12-04 14:29:11 -0800791 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
Craig Mautner1420b932012-12-28 17:14:38 -0800792 if (newWinAnimator == null) {
793 displayAnimator.mDimWinAnimator = null;
Craig Mautner96868332012-12-04 14:29:11 -0800794 } else {
Craig Mautner96868332012-12-04 14:29:11 -0800795 // Only set dim params on the highest dimmed layer.
Craig Mautner1420b932012-12-28 17:14:38 -0800796 final WindowStateAnimator existingDimWinAnimator = displayAnimator.mDimWinAnimator;
797 // Don't turn on for an unshown surface, or for any layer but the highest dimmed layer.
Craig Mautner96868332012-12-04 14:29:11 -0800798 if (newWinAnimator.mSurfaceShown && (existingDimWinAnimator == null
799 || !existingDimWinAnimator.mSurfaceShown
800 || existingDimWinAnimator.mAnimLayer < newWinAnimator.mAnimLayer)) {
Craig Mautner1420b932012-12-28 17:14:38 -0800801 displayAnimator.mDimWinAnimator = newWinAnimator;
Craig Mautner96868332012-12-04 14:29:11 -0800802 }
803 }
804 }
805
Craig Mautnera91f9e22012-09-14 16:22:08 -0700806 private DisplayContentsAnimator getDisplayContentsAnimatorLocked(int displayId) {
807 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
808 if (displayAnimator == null) {
Craig Mautnerac439e52012-09-21 08:58:34 -0700809 displayAnimator = new DisplayContentsAnimator(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700810 mDisplayContentsAnimators.put(displayId, displayAnimator);
811 }
812 return displayAnimator;
813 }
814
815 void setScreenRotationAnimationLocked(int displayId, ScreenRotationAnimation animation) {
816 getDisplayContentsAnimatorLocked(displayId).mScreenRotationAnimation = animation;
817 }
818
819 ScreenRotationAnimation getScreenRotationAnimationLocked(int displayId) {
820 return getDisplayContentsAnimatorLocked(displayId).mScreenRotationAnimation;
821 }
822
Craig Mautnerac439e52012-09-21 08:58:34 -0700823 private class DisplayContentsAnimator {
Craig Mautner1420b932012-12-28 17:14:38 -0800824 DimLayer mDimAnimator = null;
825 WindowStateAnimator mDimWinAnimator = null;
826 DimLayer mWindowAnimationBackgroundSurface = null;
Craig Mautnera91f9e22012-09-14 16:22:08 -0700827 ScreenRotationAnimation mScreenRotationAnimation = null;
Craig Mautnerac439e52012-09-21 08:58:34 -0700828
829 public DisplayContentsAnimator(int displayId) {
Craig Mautner1420b932012-12-28 17:14:38 -0800830 mDimAnimator = new DimLayer(mService, displayId);
831 mWindowAnimationBackgroundSurface = new DimLayer(mService, displayId);
Craig Mautnerac439e52012-09-21 08:58:34 -0700832 }
Craig Mautnera91f9e22012-09-14 16:22:08 -0700833 }
Craig Mautner764983d2012-03-22 11:37:36 -0700834}