blob: 67daf751d45634581ea614aa1ba0f8a7d63f3d96 [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 Mautner343ad712013-02-13 22:37:26 -080013import static com.android.server.wm.WindowManagerService.FORWARD_ITERATOR;
14import static com.android.server.wm.WindowManagerService.REVERSE_ITERATOR;
Craig Mautnera608b882012-03-30 13:03:49 -070015
Craig Mautner764983d2012-03-22 11:37:36 -070016import android.content.Context;
Dianne Hackborn98129732012-11-01 16:28:16 -070017import android.os.Debug;
Craig Mautner764983d2012-03-22 11:37:36 -070018import android.os.SystemClock;
19import android.util.Log;
20import android.util.Slog;
Craig Mautnera91f9e22012-09-14 16:22:08 -070021import android.util.SparseArray;
Craig Mautner76a71652012-09-03 23:23:58 -070022import android.util.SparseIntArray;
Dianne Hackborn529e7442012-11-01 14:22:28 -070023import android.util.TimeUtils;
Craig Mautner1420b932012-12-28 17:14:38 -080024import android.util.TypedValue;
Craig Mautner6881a102012-07-27 13:04:51 -070025import android.view.Display;
Craig Mautner764983d2012-03-22 11:37:36 -070026import android.view.Surface;
Mathias Agopian3866f0d2013-02-11 22:08:48 -080027import android.view.SurfaceControl;
Craig Mautner764983d2012-03-22 11:37:36 -070028import android.view.WindowManagerPolicy;
29import android.view.animation.Animation;
Craig Mautner764983d2012-03-22 11:37:36 -070030
Craig Mautner496bdbb2013-02-14 09:32:55 -080031import com.android.server.wm.DisplayContent.AppTokenIterator;
Craig Mautner66f78d72012-12-04 16:46:50 -080032import com.android.server.wm.WindowManagerService.DisplayContentsIterator;
Dianne Hackborn529e7442012-11-01 14:22:28 -070033import com.android.server.wm.WindowManagerService.LayoutFields;
Craig Mautner764983d2012-03-22 11:37:36 -070034
Craig Mautnere7ae2502012-03-26 17:11:19 -070035import java.io.PrintWriter;
Dianne Hackborn0c2acff2012-04-12 15:17:07 -070036import java.util.ArrayList;
Craig Mautnere7ae2502012-03-26 17:11:19 -070037
Craig Mautner764983d2012-03-22 11:37:36 -070038/**
Craig Mautner764983d2012-03-22 11:37:36 -070039 * Singleton class that carries out the animations and Surface operations in a separate task
40 * on behalf of WindowManagerService.
41 */
42public class WindowAnimator {
Craig Mautnerbb1449b2012-03-23 16:11:14 -070043 private static final String TAG = "WindowAnimator";
Craig Mautner764983d2012-03-22 11:37:36 -070044
Craig Mautner1420b932012-12-28 17:14:38 -080045 /** Amount of time in milliseconds to animate the dim surface from one value to another,
46 * when no window animation is driving it. */
47 static final int DEFAULT_DIM_DURATION = 200;
48
Craig Mautner764983d2012-03-22 11:37:36 -070049 final WindowManagerService mService;
50 final Context mContext;
51 final WindowManagerPolicy mPolicy;
52
53 boolean mAnimating;
Craig Mautner01cd0e72012-06-18 10:19:11 -070054
Craig Mautner1caa3992012-06-22 09:46:48 -070055 final Runnable mAnimationRunnable;
56
Craig Mautner764983d2012-03-22 11:37:36 -070057 int mAdjResult;
58
Craig Mautner764983d2012-03-22 11:37:36 -070059 /** Time of current animation step. Reset on each iteration */
60 long mCurrentTime;
61
62 /** Skip repeated AppWindowTokens initialization. Note that AppWindowsToken's version of this
63 * 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 -070064 private int mAnimTransactionSequence;
Craig Mautner764983d2012-03-22 11:37:36 -070065
Craig Mautnerae446592012-12-06 19:05:05 -080066 /** Window currently running an animation that has requested it be detached
67 * from the wallpaper. This means we need to ensure the wallpaper is
68 * visible behind it in case it animates in a way that would allow it to be
69 * seen. If multiple windows satisfy this, use the lowest window. */
Craig Mautnere7ae2502012-03-26 17:11:19 -070070 WindowState mWindowDetachedWallpaper = null;
Craig Mautner01cd0e72012-06-18 10:19:11 -070071
Dianne Hackborna4b7f2f2012-05-21 11:28:41 -070072 WindowStateAnimator mUniverseBackground = null;
73 int mAboveUniverseLayer = 0;
74
Craig Mautnera608b882012-03-30 13:03:49 -070075 int mBulkUpdateParams = 0;
76
Craig Mautnera91f9e22012-09-14 16:22:08 -070077 SparseArray<DisplayContentsAnimator> mDisplayContentsAnimators =
78 new SparseArray<WindowAnimator.DisplayContentsAnimator>();
Craig Mautnerd09cc4b2012-04-04 10:23:31 -070079
Craig Mautnerb47bbc32012-08-22 17:41:48 -070080 boolean mInitialized = false;
81
Craig Mautner178af592012-09-17 10:37:29 -070082 // forceHiding states.
83 static final int KEYGUARD_NOT_SHOWN = 0;
84 static final int KEYGUARD_ANIMATING_IN = 1;
85 static final int KEYGUARD_SHOWN = 2;
86 static final int KEYGUARD_ANIMATING_OUT = 3;
87 int mForceHiding = KEYGUARD_NOT_SHOWN;
88
89 private String forceHidingToString() {
90 switch (mForceHiding) {
91 case KEYGUARD_NOT_SHOWN: return "KEYGUARD_NOT_SHOWN";
92 case KEYGUARD_ANIMATING_IN: return "KEYGUARD_ANIMATING_IN";
93 case KEYGUARD_SHOWN: return "KEYGUARD_SHOWN";
94 case KEYGUARD_ANIMATING_OUT:return "KEYGUARD_ANIMATING_OUT";
95 default: return "KEYGUARD STATE UNKNOWN " + mForceHiding;
96 }
97 }
98
Craig Mautner918b53b2012-07-09 14:15:54 -070099 WindowAnimator(final WindowManagerService service) {
Craig Mautner764983d2012-03-22 11:37:36 -0700100 mService = service;
Craig Mautner918b53b2012-07-09 14:15:54 -0700101 mContext = service.mContext;
102 mPolicy = service.mPolicy;
Craig Mautner1caa3992012-06-22 09:46:48 -0700103
104 mAnimationRunnable = new Runnable() {
105 @Override
106 public void run() {
Craig Mautner96868332012-12-04 14:29:11 -0800107 synchronized (mService.mWindowMap) {
108 mService.mAnimationScheduled = false;
109 animateLocked();
Craig Mautner1caa3992012-06-22 09:46:48 -0700110 }
111 }
112 };
Craig Mautnerb47bbc32012-08-22 17:41:48 -0700113 }
Craig Mautner9e809442012-06-22 17:13:04 -0700114
Craig Mautnera91f9e22012-09-14 16:22:08 -0700115 void addDisplayLocked(final int displayId) {
Craig Mautnerac439e52012-09-21 08:58:34 -0700116 // Create the DisplayContentsAnimator object by retrieving it.
117 getDisplayContentsAnimatorLocked(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700118 if (displayId == Display.DEFAULT_DISPLAY) {
119 mInitialized = true;
120 }
121 }
122
123 void removeDisplayLocked(final int displayId) {
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700124 final DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
125 if (displayAnimator != null) {
126 if (displayAnimator.mWindowAnimationBackgroundSurface != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800127 displayAnimator.mWindowAnimationBackgroundSurface.destroySurface();
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700128 displayAnimator.mWindowAnimationBackgroundSurface = null;
129 }
130 if (displayAnimator.mScreenRotationAnimation != null) {
131 displayAnimator.mScreenRotationAnimation.kill();
132 displayAnimator.mScreenRotationAnimation = null;
133 }
134 if (displayAnimator.mDimAnimator != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800135 displayAnimator.mDimAnimator.destroySurface();
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700136 displayAnimator.mDimAnimator = null;
137 }
138 }
139
Craig Mautnera91f9e22012-09-14 16:22:08 -0700140 mDisplayContentsAnimators.delete(displayId);
Craig Mautner1caa3992012-06-22 09:46:48 -0700141 }
142
Craig Mautner96868332012-12-04 14:29:11 -0800143 AppWindowAnimator getWallpaperAppAnimator() {
144 return mService.mWallpaperTarget == null
145 ? null : mService.mWallpaperTarget.mAppToken == null
146 ? null : mService.mWallpaperTarget.mAppToken.mAppAnimator;
Craig Mautner711f90a2012-07-03 18:43:52 -0700147 }
148
Craig Mautner96868332012-12-04 14:29:11 -0800149 void hideWallpapersLocked(final WindowState w) {
150 final WindowState wallpaperTarget = mService.mWallpaperTarget;
151 final WindowState lowerWallpaperTarget = mService.mLowerWallpaperTarget;
152 final ArrayList<WindowToken> wallpaperTokens = mService.mWallpaperTokens;
Craig Mautner66f78d72012-12-04 16:46:50 -0800153
Dianne Hackborn98129732012-11-01 16:28:16 -0700154 if ((wallpaperTarget == w && lowerWallpaperTarget == null) || wallpaperTarget == null) {
155 final int numTokens = wallpaperTokens.size();
Craig Mautner918b53b2012-07-09 14:15:54 -0700156 for (int i = numTokens - 1; i >= 0; i--) {
Dianne Hackborn98129732012-11-01 16:28:16 -0700157 final WindowToken token = wallpaperTokens.get(i);
Craig Mautner918b53b2012-07-09 14:15:54 -0700158 final int numWindows = token.windows.size();
159 for (int j = numWindows - 1; j >= 0; j--) {
160 final WindowState wallpaper = token.windows.get(j);
Craig Mautnerb9836b92012-06-11 11:40:09 -0700161 final WindowStateAnimator winAnimator = wallpaper.mWinAnimator;
162 if (!winAnimator.mLastHidden) {
163 winAnimator.hide();
Craig Mautner507a2ee2012-06-13 08:39:38 -0700164 mService.dispatchWallpaperVisibility(wallpaper, false);
Craig Mautner76a71652012-09-03 23:23:58 -0700165 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
166 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnerb9836b92012-06-11 11:40:09 -0700167 }
168 }
Dianne Hackbornef03a7f2012-10-29 18:46:52 -0700169 if (WindowManagerService.DEBUG_WALLPAPER_LIGHT && !token.hidden) Slog.d(TAG,
Dianne Hackborn2ea9bae2012-11-02 18:43:48 -0700170 "Hiding wallpaper " + token + " from " + w
171 + " target=" + wallpaperTarget + " lower=" + lowerWallpaperTarget
172 + "\n" + Debug.getCallers(5, " "));
Craig Mautnerb9836b92012-06-11 11:40:09 -0700173 token.hidden = true;
Craig Mautner0afddcb2012-05-08 15:38:00 -0700174 }
Craig Mautner0afddcb2012-05-08 15:38:00 -0700175 }
176 }
177
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800178 private void updateAppWindowsLocked(int displayId) {
Craig Mautner764983d2012-03-22 11:37:36 -0700179 int i;
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800180 final DisplayContent displayContent = mService.getDisplayContentLocked(displayId);
Craig Mautner343ad712013-02-13 22:37:26 -0800181 AppTokenIterator iterator = displayContent.getTmpAppIterator(FORWARD_ITERATOR);
Craig Mautner496bdbb2013-02-14 09:32:55 -0800182 while (iterator.hasNext()) {
183 final AppWindowAnimator appAnimator = iterator.next().mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700184 final boolean wasAnimating = appAnimator.animation != null
Craig Mautnerfbf378c2012-04-23 17:24:21 -0700185 && appAnimator.animation != AppWindowAnimator.sDummyAnimation;
Craig Mautner9339c402012-11-30 11:23:56 -0800186 if (appAnimator.stepAnimationLocked(mCurrentTime)) {
Craig Mautner764983d2012-03-22 11:37:36 -0700187 mAnimating = true;
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700188 } else if (wasAnimating) {
189 // stopped animating, do one more pass through the layout
Craig Mautner76a71652012-09-03 23:23:58 -0700190 setAppLayoutChanges(appAnimator, WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
191 "appToken " + appAnimator.mAppToken + " done");
Craig Mautner83339b42012-05-01 22:13:23 -0700192 if (WindowManagerService.DEBUG_ANIM) Slog.v(TAG,
193 "updateWindowsApps...: done animating " + appAnimator.mAppToken);
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700194 }
195 }
Craig Mautnera2c77052012-03-26 12:14:43 -0700196
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800197 final AppTokenList exitingAppTokens = displayContent.mExitingAppTokens;
198 final int NEAT = exitingAppTokens.size();
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700199 for (i=0; i<NEAT; i++) {
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800200 final AppWindowAnimator appAnimator = exitingAppTokens.get(i).mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700201 final boolean wasAnimating = appAnimator.animation != null
Craig Mautnerfbf378c2012-04-23 17:24:21 -0700202 && appAnimator.animation != AppWindowAnimator.sDummyAnimation;
Craig Mautner9339c402012-11-30 11:23:56 -0800203 if (appAnimator.stepAnimationLocked(mCurrentTime)) {
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700204 mAnimating = true;
205 } else if (wasAnimating) {
206 // stopped animating, do one more pass through the layout
Craig Mautner76a71652012-09-03 23:23:58 -0700207 setAppLayoutChanges(appAnimator, WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
208 "exiting appToken " + appAnimator.mAppToken + " done");
Craig Mautner83339b42012-05-01 22:13:23 -0700209 if (WindowManagerService.DEBUG_ANIM) Slog.v(TAG,
210 "updateWindowsApps...: done animating exiting " + appAnimator.mAppToken);
Craig Mautner764983d2012-03-22 11:37:36 -0700211 }
212 }
Craig Mautner764983d2012-03-22 11:37:36 -0700213 }
214
Craig Mautnera91f9e22012-09-14 16:22:08 -0700215 private void updateWindowsLocked(final int displayId) {
Craig Mautner6fbda632012-07-03 09:26:39 -0700216 ++mAnimTransactionSequence;
Craig Mautner764983d2012-03-22 11:37:36 -0700217
Craig Mautner96868332012-12-04 14:29:11 -0800218 final WindowList windows = mService.getWindowListLocked(displayId);
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700219 ArrayList<WindowStateAnimator> unForceHiding = null;
220 boolean wallpaperInUnForceHiding = false;
Craig Mautner178af592012-09-17 10:37:29 -0700221 mForceHiding = KEYGUARD_NOT_SHOWN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700222
Craig Mautner96868332012-12-04 14:29:11 -0800223 for (int i = windows.size() - 1; i >= 0; i--) {
224 WindowState win = windows.get(i);
225 WindowStateAnimator winAnimator = win.mWinAnimator;
Craig Mautnerbec53f72012-04-05 11:49:05 -0700226 final int flags = winAnimator.mAttrFlags;
Craig Mautner764983d2012-03-22 11:37:36 -0700227
Mathias Agopian29479eb2013-02-14 14:36:04 -0800228 if (winAnimator.mSurfaceControl != null) {
Craig Mautnera2c77052012-03-26 12:14:43 -0700229 final boolean wasAnimating = winAnimator.mWasAnimating;
230 final boolean nowAnimating = winAnimator.stepAnimationLocked(mCurrentTime);
Craig Mautner764983d2012-03-22 11:37:36 -0700231
232 if (WindowManagerService.DEBUG_WALLPAPER) {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700233 Slog.v(TAG, win + ": wasAnimating=" + wasAnimating +
Craig Mautner764983d2012-03-22 11:37:36 -0700234 ", nowAnimating=" + nowAnimating);
235 }
236
Craig Mautner96868332012-12-04 14:29:11 -0800237 if (wasAnimating && !winAnimator.mAnimating && mService.mWallpaperTarget == win) {
Craig Mautnera608b882012-03-30 13:03:49 -0700238 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
Craig Mautner76a71652012-09-03 23:23:58 -0700239 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
240 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700241 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700242 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 2",
Craig Mautner66f78d72012-12-04 16:46:50 -0800243 getPendingLayoutChanges(Display.DEFAULT_DISPLAY));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700244 }
Craig Mautner764983d2012-03-22 11:37:36 -0700245 }
246
Craig Mautnerbec53f72012-04-05 11:49:05 -0700247 if (mPolicy.doesForceHide(win, win.mAttrs)) {
Craig Mautner764983d2012-03-22 11:37:36 -0700248 if (!wasAnimating && nowAnimating) {
Craig Mautner83339b42012-05-01 22:13:23 -0700249 if (WindowManagerService.DEBUG_ANIM ||
250 WindowManagerService.DEBUG_VISIBILITY) Slog.v(TAG,
251 "Animation started that could impact force hide: " + win);
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700252 mBulkUpdateParams |= SET_FORCE_HIDING_CHANGED;
Craig Mautner76a71652012-09-03 23:23:58 -0700253 setPendingLayoutChanges(displayId,
254 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700255 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700256 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 3",
Craig Mautner66f78d72012-12-04 16:46:50 -0800257 getPendingLayoutChanges(displayId));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700258 }
Craig Mautner764983d2012-03-22 11:37:36 -0700259 mService.mFocusMayChange = true;
Dianne Hackbornac920872012-05-22 11:49:49 -0700260 }
Craig Mautner4bf18a72012-07-10 14:08:16 -0700261 if (win.isReadyForDisplay()) {
262 if (nowAnimating) {
263 if (winAnimator.mAnimationIsEntrance) {
Craig Mautner178af592012-09-17 10:37:29 -0700264 mForceHiding = KEYGUARD_ANIMATING_IN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700265 } else {
Craig Mautner178af592012-09-17 10:37:29 -0700266 mForceHiding = KEYGUARD_ANIMATING_OUT;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700267 }
268 } else {
Craig Mautner178af592012-09-17 10:37:29 -0700269 mForceHiding = KEYGUARD_SHOWN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700270 }
Craig Mautner764983d2012-03-22 11:37:36 -0700271 }
Dianne Hackbornac920872012-05-22 11:49:49 -0700272 if (WindowManagerService.DEBUG_VISIBILITY) Slog.v(TAG,
Craig Mautner178af592012-09-17 10:37:29 -0700273 "Force hide " + mForceHiding
Dianne Hackbornac920872012-05-22 11:49:49 -0700274 + " hasSurface=" + win.mHasSurface
275 + " policyVis=" + win.mPolicyVisibility
276 + " destroying=" + win.mDestroying
277 + " attHidden=" + win.mAttachedHidden
278 + " vis=" + win.mViewVisibility
279 + " hidden=" + win.mRootToken.hidden
280 + " anim=" + win.mWinAnimator.mAnimation);
Craig Mautnerbec53f72012-04-05 11:49:05 -0700281 } else if (mPolicy.canBeForceHidden(win, win.mAttrs)) {
Craig Mautner4bf18a72012-07-10 14:08:16 -0700282 final boolean hideWhenLocked =
283 (winAnimator.mAttrFlags & FLAG_SHOW_WHEN_LOCKED) == 0;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700284 final boolean changed;
Craig Mautner178af592012-09-17 10:37:29 -0700285 if (((mForceHiding == KEYGUARD_ANIMATING_IN)
Craig Mautner4bf18a72012-07-10 14:08:16 -0700286 && (!winAnimator.isAnimating() || hideWhenLocked))
Craig Mautner178af592012-09-17 10:37:29 -0700287 || ((mForceHiding == KEYGUARD_SHOWN) && hideWhenLocked)) {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700288 changed = win.hideLw(false, false);
Craig Mautner764983d2012-03-22 11:37:36 -0700289 if (WindowManagerService.DEBUG_VISIBILITY && changed) Slog.v(TAG,
Craig Mautnerbec53f72012-04-05 11:49:05 -0700290 "Now policy hidden: " + win);
Craig Mautner764983d2012-03-22 11:37:36 -0700291 } else {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700292 changed = win.showLw(false, false);
Craig Mautner764983d2012-03-22 11:37:36 -0700293 if (WindowManagerService.DEBUG_VISIBILITY && changed) Slog.v(TAG,
Craig Mautnerbec53f72012-04-05 11:49:05 -0700294 "Now policy shown: " + win);
Craig Mautner764983d2012-03-22 11:37:36 -0700295 if (changed) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700296 if ((mBulkUpdateParams & SET_FORCE_HIDING_CHANGED) != 0
Craig Mautnerbec53f72012-04-05 11:49:05 -0700297 && win.isVisibleNow() /*w.isReadyForDisplay()*/) {
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700298 if (unForceHiding == null) {
299 unForceHiding = new ArrayList<WindowStateAnimator>();
300 }
301 unForceHiding.add(winAnimator);
Craig Mautner01cd0e72012-06-18 10:19:11 -0700302 if ((flags & FLAG_SHOW_WALLPAPER) != 0) {
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700303 wallpaperInUnForceHiding = true;
Craig Mautner764983d2012-03-22 11:37:36 -0700304 }
305 }
Craig Mautnerbec53f72012-04-05 11:49:05 -0700306 if (mCurrentFocus == null || mCurrentFocus.mLayer < win.mLayer) {
Craig Mautner764983d2012-03-22 11:37:36 -0700307 // We are showing on to of the current
308 // focus, so re-evaluate focus to make
309 // sure it is correct.
310 mService.mFocusMayChange = true;
311 }
312 }
313 }
Craig Mautner01cd0e72012-06-18 10:19:11 -0700314 if (changed && (flags & FLAG_SHOW_WALLPAPER) != 0) {
Craig Mautnera608b882012-03-30 13:03:49 -0700315 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
Craig Mautner76a71652012-09-03 23:23:58 -0700316 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
317 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700318 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700319 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 4",
Craig Mautner66f78d72012-12-04 16:46:50 -0800320 getPendingLayoutChanges(Display.DEFAULT_DISPLAY));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700321 }
Craig Mautner764983d2012-03-22 11:37:36 -0700322 }
323 }
324 }
325
Craig Mautnerbec53f72012-04-05 11:49:05 -0700326 final AppWindowToken atoken = win.mAppToken;
Craig Mautner6fbda632012-07-03 09:26:39 -0700327 if (winAnimator.mDrawState == WindowStateAnimator.READY_TO_SHOW) {
328 if (atoken == null || atoken.allDrawn) {
329 if (winAnimator.performShowLocked()) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800330 setPendingLayoutChanges(displayId,
Craig Mautner76a71652012-09-03 23:23:58 -0700331 WindowManagerPolicy.FINISH_LAYOUT_REDO_ANIM);
Craig Mautner6fbda632012-07-03 09:26:39 -0700332 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
333 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 5",
Craig Mautner66f78d72012-12-04 16:46:50 -0800334 getPendingLayoutChanges(displayId));
Craig Mautner764983d2012-03-22 11:37:36 -0700335 }
336 }
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700337 }
Craig Mautner764983d2012-03-22 11:37:36 -0700338 }
Craig Mautner322e4032012-07-13 13:35:20 -0700339 final AppWindowAnimator appAnimator = winAnimator.mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700340 if (appAnimator != null && appAnimator.thumbnail != null) {
Craig Mautner6fbda632012-07-03 09:26:39 -0700341 if (appAnimator.thumbnailTransactionSeq != mAnimTransactionSequence) {
342 appAnimator.thumbnailTransactionSeq = mAnimTransactionSequence;
Craig Mautner59431632012-04-04 11:56:44 -0700343 appAnimator.thumbnailLayer = 0;
Dianne Hackborn8078d8c2012-03-20 11:11:26 -0700344 }
Craig Mautner59431632012-04-04 11:56:44 -0700345 if (appAnimator.thumbnailLayer < winAnimator.mAnimLayer) {
346 appAnimator.thumbnailLayer = winAnimator.mAnimLayer;
Dianne Hackborn8078d8c2012-03-20 11:11:26 -0700347 }
348 }
Craig Mautner764983d2012-03-22 11:37:36 -0700349 } // end forall windows
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700350
Craig Mautner078ea0a2012-06-25 11:04:29 -0700351 // If we have windows that are being show due to them no longer
352 // being force-hidden, apply the appropriate animation to them.
353 if (unForceHiding != null) {
354 for (int i=unForceHiding.size()-1; i>=0; i--) {
355 Animation a = mPolicy.createForceHideEnterAnimation(wallpaperInUnForceHiding);
356 if (a != null) {
357 final WindowStateAnimator winAnimator = unForceHiding.get(i);
358 winAnimator.setAnimation(a);
359 winAnimator.mAnimationIsEntrance = true;
360 }
361 }
362 }
363 }
364
Craig Mautnera91f9e22012-09-14 16:22:08 -0700365 private void updateWallpaperLocked(int displayId) {
366 final DisplayContentsAnimator displayAnimator =
367 getDisplayContentsAnimatorLocked(displayId);
Craig Mautner96868332012-12-04 14:29:11 -0800368 final WindowList windows = mService.getWindowListLocked(displayId);
Craig Mautner078ea0a2012-06-25 11:04:29 -0700369 WindowStateAnimator windowAnimationBackground = null;
370 int windowAnimationBackgroundColor = 0;
371 WindowState detachedWallpaper = null;
372
Craig Mautner96868332012-12-04 14:29:11 -0800373 for (int i = windows.size() - 1; i >= 0; i--) {
374 final WindowState win = windows.get(i);
375 WindowStateAnimator winAnimator = win.mWinAnimator;
Mathias Agopian29479eb2013-02-14 14:36:04 -0800376 if (winAnimator.mSurfaceControl == null) {
Craig Mautner078ea0a2012-06-25 11:04:29 -0700377 continue;
378 }
379
380 final int flags = winAnimator.mAttrFlags;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700381
382 // If this window is animating, make a note that we have
383 // an animating window and take care of a request to run
384 // a detached wallpaper animation.
385 if (winAnimator.mAnimating) {
386 if (winAnimator.mAnimation != null) {
387 if ((flags & FLAG_SHOW_WALLPAPER) != 0
388 && winAnimator.mAnimation.getDetachWallpaper()) {
389 detachedWallpaper = win;
390 }
391 final int backgroundColor = winAnimator.mAnimation.getBackgroundColor();
392 if (backgroundColor != 0) {
393 if (windowAnimationBackground == null || (winAnimator.mAnimLayer <
394 windowAnimationBackground.mAnimLayer)) {
395 windowAnimationBackground = winAnimator;
396 windowAnimationBackgroundColor = backgroundColor;
397 }
398 }
399 }
400 mAnimating = true;
401 }
402
403 // If this window's app token is running a detached wallpaper
404 // animation, make a note so we can ensure the wallpaper is
405 // displayed behind it.
Craig Mautner322e4032012-07-13 13:35:20 -0700406 final AppWindowAnimator appAnimator = winAnimator.mAppAnimator;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700407 if (appAnimator != null && appAnimator.animation != null
408 && appAnimator.animating) {
409 if ((flags & FLAG_SHOW_WALLPAPER) != 0
410 && appAnimator.animation.getDetachWallpaper()) {
411 detachedWallpaper = win;
412 }
413
414 final int backgroundColor = appAnimator.animation.getBackgroundColor();
415 if (backgroundColor != 0) {
416 if (windowAnimationBackground == null || (winAnimator.mAnimLayer <
417 windowAnimationBackground.mAnimLayer)) {
418 windowAnimationBackground = winAnimator;
419 windowAnimationBackgroundColor = backgroundColor;
420 }
421 }
422 }
423 } // end forall windows
424
Craig Mautner9e809442012-06-22 17:13:04 -0700425 if (mWindowDetachedWallpaper != detachedWallpaper) {
426 if (WindowManagerService.DEBUG_WALLPAPER) Slog.v(TAG,
427 "Detached wallpaper changed from " + mWindowDetachedWallpaper
428 + " to " + detachedWallpaper);
429 mWindowDetachedWallpaper = detachedWallpaper;
430 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
431 }
432
433 if (windowAnimationBackgroundColor != 0) {
434 // If the window that wants black is the current wallpaper
435 // target, then the black goes *below* the wallpaper so we
436 // don't cause the wallpaper to suddenly disappear.
437 int animLayer = windowAnimationBackground.mAnimLayer;
438 WindowState win = windowAnimationBackground.mWin;
Craig Mautner96868332012-12-04 14:29:11 -0800439 if (mService.mWallpaperTarget == win || mService.mLowerWallpaperTarget == win
440 || mService.mUpperWallpaperTarget == win) {
441 final int N = windows.size();
Craig Mautner9e809442012-06-22 17:13:04 -0700442 for (int i = 0; i < N; i++) {
Craig Mautner96868332012-12-04 14:29:11 -0800443 WindowStateAnimator winAnimator = windows.get(i).mWinAnimator;
Craig Mautner918b53b2012-07-09 14:15:54 -0700444 if (winAnimator.mIsWallpaper) {
Craig Mautner9e809442012-06-22 17:13:04 -0700445 animLayer = winAnimator.mAnimLayer;
446 break;
447 }
448 }
449 }
450
Craig Mautner1420b932012-12-28 17:14:38 -0800451 displayAnimator.mWindowAnimationBackgroundSurface.show(
452 animLayer - WindowManagerService.LAYER_OFFSET_DIM,
453 ((windowAnimationBackgroundColor >> 24) & 0xff) / 255f, 0);
Craig Mautner9e809442012-06-22 17:13:04 -0700454 } else {
Craig Mautner1420b932012-12-28 17:14:38 -0800455 displayAnimator.mWindowAnimationBackgroundSurface.hide();
Craig Mautner9e809442012-06-22 17:13:04 -0700456 }
Craig Mautner764983d2012-03-22 11:37:36 -0700457 }
458
Craig Mautner9339c402012-11-30 11:23:56 -0800459 /** See if any windows have been drawn, so they (and others associated with them) can now be
460 * shown. */
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800461 private void testTokenMayBeDrawnLocked(int displayId) {
Craig Mautner96868332012-12-04 14:29:11 -0800462 // See if any windows have been drawn, so they (and others
463 // associated with them) can now be shown.
Craig Mautner343ad712013-02-13 22:37:26 -0800464 AppTokenIterator iterator =
465 mService.getDisplayContentLocked(displayId).getTmpAppIterator(FORWARD_ITERATOR);
Craig Mautner496bdbb2013-02-14 09:32:55 -0800466 while (iterator.hasNext()) {
467 AppWindowToken wtoken = iterator.next();
Craig Mautner96868332012-12-04 14:29:11 -0800468 AppWindowAnimator appAnimator = wtoken.mAppAnimator;
Craig Mautner6fbda632012-07-03 09:26:39 -0700469 final boolean allDrawn = wtoken.allDrawn;
Craig Mautner322e4032012-07-13 13:35:20 -0700470 if (allDrawn != appAnimator.allDrawn) {
471 appAnimator.allDrawn = allDrawn;
Craig Mautner6fbda632012-07-03 09:26:39 -0700472 if (allDrawn) {
473 // The token has now changed state to having all
474 // windows shown... what to do, what to do?
Craig Mautner322e4032012-07-13 13:35:20 -0700475 if (appAnimator.freezingScreen) {
476 appAnimator.showAllWindowsLocked();
Craig Mautner6fbda632012-07-03 09:26:39 -0700477 mService.unsetAppFreezingScreenLocked(wtoken, false, true);
478 if (WindowManagerService.DEBUG_ORIENTATION) Slog.i(TAG,
479 "Setting mOrientationChangeComplete=true because wtoken "
480 + wtoken + " numInteresting=" + wtoken.numInterestingWindows
481 + " numDrawn=" + wtoken.numDrawnWindows);
482 // This will set mOrientationChangeComplete and cause a pass through layout.
Craig Mautner76a71652012-09-03 23:23:58 -0700483 setAppLayoutChanges(appAnimator,
484 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
485 "testTokenMayBeDrawnLocked: freezingScreen");
Craig Mautner6fbda632012-07-03 09:26:39 -0700486 } else {
Craig Mautner76a71652012-09-03 23:23:58 -0700487 setAppLayoutChanges(appAnimator,
488 WindowManagerPolicy.FINISH_LAYOUT_REDO_ANIM,
489 "testTokenMayBeDrawnLocked");
Craig Mautner66f78d72012-12-04 16:46:50 -0800490
Craig Mautner6fbda632012-07-03 09:26:39 -0700491 // We can now show all of the drawn windows!
492 if (!mService.mOpeningApps.contains(wtoken)) {
Craig Mautner322e4032012-07-13 13:35:20 -0700493 mAnimating |= appAnimator.showAllWindowsLocked();
Craig Mautner6fbda632012-07-03 09:26:39 -0700494 }
Craig Mautner764983d2012-03-22 11:37:36 -0700495 }
496 }
497 }
498 }
499 }
500
Craig Mautnera91f9e22012-09-14 16:22:08 -0700501 private void performAnimationsLocked(final int displayId) {
502 updateWindowsLocked(displayId);
503 updateWallpaperLocked(displayId);
Craig Mautner764983d2012-03-22 11:37:36 -0700504 }
505
Craig Mautner1420b932012-12-28 17:14:38 -0800506 private long getDimBehindFadeDuration(long duration) {
507 TypedValue tv = new TypedValue();
508 mContext.getResources().getValue(
509 com.android.internal.R.fraction.config_dimBehindFadeDuration, tv, true);
510 if (tv.type == TypedValue.TYPE_FRACTION) {
511 duration = (long)tv.getFraction(duration, duration);
512 } else if (tv.type >= TypedValue.TYPE_FIRST_INT && tv.type <= TypedValue.TYPE_LAST_INT) {
513 duration = tv.data;
514 }
515 return duration;
516 }
517
518 /** Locked on mService.mWindowMap. */
Craig Mautner1caa3992012-06-22 09:46:48 -0700519 private void animateLocked() {
Craig Mautnerb47bbc32012-08-22 17:41:48 -0700520 if (!mInitialized) {
521 return;
522 }
Craig Mautner59c00972012-07-30 12:10:24 -0700523
Craig Mautner764983d2012-03-22 11:37:36 -0700524 mCurrentTime = SystemClock.uptimeMillis();
Craig Mautner2639da52012-07-09 09:39:06 -0700525 mBulkUpdateParams = SET_ORIENTATION_CHANGE_COMPLETE;
Chet Haase198e5642012-05-10 09:55:15 -0700526 boolean wasAnimating = mAnimating;
Craig Mautner7d8df392012-04-06 15:26:23 -0700527 mAnimating = false;
528 if (WindowManagerService.DEBUG_WINDOW_TRACE) {
529 Slog.i(TAG, "!!! animate: entry time=" + mCurrentTime);
530 }
Craig Mautner764983d2012-03-22 11:37:36 -0700531
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700532 if (WindowManagerService.SHOW_TRANSACTIONS) Slog.i(
533 TAG, ">>> OPEN TRANSACTION animateLocked");
Mathias Agopian3866f0d2013-02-11 22:08:48 -0800534 SurfaceControl.openTransaction();
535 SurfaceControl.setAnimationTransaction();
Craig Mautner764983d2012-03-22 11:37:36 -0700536 try {
Craig Mautnera91f9e22012-09-14 16:22:08 -0700537 final int numDisplays = mDisplayContentsAnimators.size();
538 for (int i = 0; i < numDisplays; i++) {
539 final int displayId = mDisplayContentsAnimators.keyAt(i);
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800540 updateAppWindowsLocked(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700541 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
542
543 final ScreenRotationAnimation screenRotationAnimation =
544 displayAnimator.mScreenRotationAnimation;
545 if (screenRotationAnimation != null && screenRotationAnimation.isAnimating()) {
546 if (screenRotationAnimation.stepAnimationLocked(mCurrentTime)) {
547 mAnimating = true;
548 } else {
549 mBulkUpdateParams |= SET_UPDATE_ROTATION;
550 screenRotationAnimation.kill();
551 displayAnimator.mScreenRotationAnimation = null;
552 }
553 }
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700554
555 // Update animations of all applications, including those
556 // associated with exiting/removed apps
Craig Mautnera91f9e22012-09-14 16:22:08 -0700557 performAnimationsLocked(displayId);
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700558
Craig Mautner96868332012-12-04 14:29:11 -0800559 final WindowList windows = mService.getWindowListLocked(displayId);
560 final int N = windows.size();
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700561 for (int j = 0; j < N; j++) {
Craig Mautner96868332012-12-04 14:29:11 -0800562 windows.get(j).mWinAnimator.prepareSurfaceLocked(true);
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700563 }
564 }
565
Craig Mautnera91f9e22012-09-14 16:22:08 -0700566 for (int i = 0; i < numDisplays; i++) {
567 final int displayId = mDisplayContentsAnimators.keyAt(i);
Craig Mautnerb1fd65c02013-02-05 13:34:57 -0800568
569 testTokenMayBeDrawnLocked(displayId);
570
Craig Mautnera91f9e22012-09-14 16:22:08 -0700571 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
Craig Mautner764983d2012-03-22 11:37:36 -0700572
Craig Mautnera91f9e22012-09-14 16:22:08 -0700573 final ScreenRotationAnimation screenRotationAnimation =
574 displayAnimator.mScreenRotationAnimation;
575 if (screenRotationAnimation != null) {
576 screenRotationAnimation.updateSurfacesInTransaction();
577 }
578
Craig Mautner1420b932012-12-28 17:14:38 -0800579 final DimLayer dimAnimator = displayAnimator.mDimAnimator;
580 final WindowStateAnimator winAnimator = displayAnimator.mDimWinAnimator;
Craig Mautner13131e72013-01-11 11:03:33 -0800581 final int dimLayer;
Craig Mautner1420b932012-12-28 17:14:38 -0800582 final float dimAmount;
583 if (winAnimator == null) {
Craig Mautner13131e72013-01-11 11:03:33 -0800584 dimLayer = dimAnimator.getLayer();
Craig Mautner1420b932012-12-28 17:14:38 -0800585 dimAmount = 0;
586 } else {
Craig Mautner13131e72013-01-11 11:03:33 -0800587 dimLayer = winAnimator.mAnimLayer - WindowManagerService.LAYER_OFFSET_DIM;
Craig Mautner1420b932012-12-28 17:14:38 -0800588 dimAmount = winAnimator.mWin.mAttrs.dimAmount;
Craig Mautnera91f9e22012-09-14 16:22:08 -0700589 }
Craig Mautner1420b932012-12-28 17:14:38 -0800590 final float targetAlpha = dimAnimator.getTargetAlpha();
591 if (targetAlpha != dimAmount) {
592 if (winAnimator == null) {
593 dimAnimator.hide(DEFAULT_DIM_DURATION);
594 } else {
595 long duration = (winAnimator.mAnimating && winAnimator.mAnimation != null)
596 ? winAnimator.mAnimation.computeDurationHint()
597 : DEFAULT_DIM_DURATION;
598 if (targetAlpha > dimAmount) {
599 duration = getDimBehindFadeDuration(duration);
600 }
Craig Mautner13131e72013-01-11 11:03:33 -0800601 dimAnimator.show(dimLayer, dimAmount, duration);
Craig Mautner1420b932012-12-28 17:14:38 -0800602 }
Craig Mautner13131e72013-01-11 11:03:33 -0800603 } else if (dimAnimator.getLayer() != dimLayer) {
604 dimAnimator.setLayer(dimLayer);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700605 }
Craig Mautner1420b932012-12-28 17:14:38 -0800606 if (dimAnimator.isAnimating()) {
607 if (!mService.okToDisplay()) {
608 // Jump to the end of the animation.
609 dimAnimator.show();
610 } else {
611 mAnimating |= dimAnimator.stepAnimation();
612 }
613 }
614
Svetoslav Ganov545252f2012-12-10 18:29:24 -0800615 //TODO (multidisplay): Magnification is supported only for the default display.
616 if (mService.mDisplayMagnifier != null && displayId == Display.DEFAULT_DISPLAY) {
617 mService.mDisplayMagnifier.drawMagnifiedRegionBorderIfNeededLocked();
618 }
Craig Mautner764983d2012-03-22 11:37:36 -0700619 }
620
Craig Mautner7358fbf2012-04-12 21:06:33 -0700621 if (mService.mWatermark != null) {
622 mService.mWatermark.drawIfNeeded();
623 }
Craig Mautner764983d2012-03-22 11:37:36 -0700624 } catch (RuntimeException e) {
625 Log.wtf(TAG, "Unhandled exception in Window Manager", e);
626 } finally {
Mathias Agopian3866f0d2013-02-11 22:08:48 -0800627 SurfaceControl.closeTransaction();
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700628 if (WindowManagerService.SHOW_TRANSACTIONS) Slog.i(
629 TAG, "<<< CLOSE TRANSACTION animateLocked");
630 }
631
Craig Mautner66f78d72012-12-04 16:46:50 -0800632 boolean hasPendingLayoutChanges = false;
633 DisplayContentsIterator iterator = mService.new DisplayContentsIterator();
634 while (iterator.hasNext()) {
635 final DisplayContent displayContent = iterator.next();
636 final int pendingChanges = getPendingLayoutChanges(displayContent.getDisplayId());
637 if ((pendingChanges & WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER) != 0) {
Craig Mautner96868332012-12-04 14:29:11 -0800638 mBulkUpdateParams |= SET_WALLPAPER_ACTION_PENDING;
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700639 }
Craig Mautner66f78d72012-12-04 16:46:50 -0800640 if (pendingChanges != 0) {
641 hasPendingLayoutChanges = true;
642 }
Craig Mautner764983d2012-03-22 11:37:36 -0700643 }
Craig Mautnerc2f9be02012-03-27 17:32:29 -0700644
Craig Mautner66f78d72012-12-04 16:46:50 -0800645 boolean doRequest = false;
646 if (mBulkUpdateParams != 0) {
647 doRequest = mService.copyAnimToLayoutParamsLocked();
648 }
649
650 if (hasPendingLayoutChanges || doRequest) {
651 mService.requestTraversalLocked();
Craig Mautner01cd0e72012-06-18 10:19:11 -0700652 }
Craig Mautner7d8df392012-04-06 15:26:23 -0700653
654 if (mAnimating) {
Craig Mautner96868332012-12-04 14:29:11 -0800655 mService.scheduleAnimationLocked();
Chet Haase198e5642012-05-10 09:55:15 -0700656 } else if (wasAnimating) {
657 mService.requestTraversalLocked();
Craig Mautner7d8df392012-04-06 15:26:23 -0700658 }
659 if (WindowManagerService.DEBUG_WINDOW_TRACE) {
660 Slog.i(TAG, "!!! animate: exit mAnimating=" + mAnimating
661 + " mBulkUpdateParams=" + Integer.toHexString(mBulkUpdateParams)
Craig Mautner76a71652012-09-03 23:23:58 -0700662 + " mPendingLayoutChanges(DEFAULT_DISPLAY)="
Craig Mautner66f78d72012-12-04 16:46:50 -0800663 + Integer.toHexString(getPendingLayoutChanges(Display.DEFAULT_DISPLAY)));
Craig Mautner7d8df392012-04-06 15:26:23 -0700664 }
Craig Mautner764983d2012-03-22 11:37:36 -0700665 }
666
667 WindowState mCurrentFocus;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700668 void setCurrentFocus(final WindowState currentFocus) {
Craig Mautner764983d2012-03-22 11:37:36 -0700669 mCurrentFocus = currentFocus;
670 }
671
Craig Mautnera91f9e22012-09-14 16:22:08 -0700672 boolean isDimmingLocked(int displayId) {
Craig Mautner1420b932012-12-28 17:14:38 -0800673 return getDisplayContentsAnimatorLocked(displayId).mDimAnimator.isDimming();
Craig Mautnerf8d4fbb2012-04-11 09:25:53 -0700674 }
675
Craig Mautnera91f9e22012-09-14 16:22:08 -0700676 boolean isDimmingLocked(final WindowStateAnimator winAnimator) {
Craig Mautner1420b932012-12-28 17:14:38 -0800677 final int displayId = winAnimator.mWin.getDisplayId();
678 DisplayContentsAnimator displayAnimator =
679 getDisplayContentsAnimatorLocked(displayId);
680 if (displayAnimator != null) {
681 return displayAnimator.mDimWinAnimator == winAnimator
682 && displayAnimator.mDimAnimator.isDimming();
683 }
684 return false;
Craig Mautneracafd192012-05-10 10:41:02 -0700685 }
686
Dianne Hackborn529e7442012-11-01 14:22:28 -0700687 static String bulkUpdateParamsToString(int bulkUpdateParams) {
688 StringBuilder builder = new StringBuilder(128);
689 if ((bulkUpdateParams & LayoutFields.SET_UPDATE_ROTATION) != 0) {
690 builder.append(" UPDATE_ROTATION");
691 }
692 if ((bulkUpdateParams & LayoutFields.SET_WALLPAPER_MAY_CHANGE) != 0) {
693 builder.append(" WALLPAPER_MAY_CHANGE");
694 }
695 if ((bulkUpdateParams & LayoutFields.SET_FORCE_HIDING_CHANGED) != 0) {
696 builder.append(" FORCE_HIDING_CHANGED");
697 }
698 if ((bulkUpdateParams & LayoutFields.SET_ORIENTATION_CHANGE_COMPLETE) != 0) {
699 builder.append(" ORIENTATION_CHANGE_COMPLETE");
700 }
701 if ((bulkUpdateParams & LayoutFields.SET_TURN_ON_SCREEN) != 0) {
702 builder.append(" TURN_ON_SCREEN");
703 }
704 return builder.toString();
705 }
706
Craig Mautnera91f9e22012-09-14 16:22:08 -0700707 public void dumpLocked(PrintWriter pw, String prefix, boolean dumpAll) {
Dianne Hackborn529e7442012-11-01 14:22:28 -0700708 final String subPrefix = " " + prefix;
709 final String subSubPrefix = " " + subPrefix;
710
Dianne Hackborn529e7442012-11-01 14:22:28 -0700711 for (int i = 0; i < mDisplayContentsAnimators.size(); i++) {
712 pw.print(prefix); pw.print("DisplayContentsAnimator #");
713 pw.print(mDisplayContentsAnimators.keyAt(i));
714 pw.println(":");
715 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
Craig Mautner96868332012-12-04 14:29:11 -0800716 final WindowList windows =
717 mService.getWindowListLocked(mDisplayContentsAnimators.keyAt(i));
718 final int N = windows.size();
719 for (int j = 0; j < N; j++) {
720 WindowStateAnimator wanim = windows.get(j).mWinAnimator;
Dianne Hackborn529e7442012-11-01 14:22:28 -0700721 pw.print(subPrefix); pw.print("Window #"); pw.print(j);
722 pw.print(": "); pw.println(wanim);
723 }
724 if (displayAnimator.mWindowAnimationBackgroundSurface != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800725 if (dumpAll || displayAnimator.mWindowAnimationBackgroundSurface.isDimming()) {
Dianne Hackborn529e7442012-11-01 14:22:28 -0700726 pw.print(subPrefix); pw.println("mWindowAnimationBackgroundSurface:");
Craig Mautnera91f9e22012-09-14 16:22:08 -0700727 displayAnimator.mWindowAnimationBackgroundSurface.printTo(subSubPrefix, pw);
728 }
Craig Mautner6fbda632012-07-03 09:26:39 -0700729 }
Craig Mautner1420b932012-12-28 17:14:38 -0800730 if (dumpAll || displayAnimator.mDimAnimator.isDimming()) {
731 pw.print(subPrefix); pw.println("mDimAnimator:");
732 displayAnimator.mDimAnimator.printTo(subSubPrefix, pw);
733 pw.print(subPrefix); pw.print("mDimWinAnimator=");
734 pw.println(displayAnimator.mDimWinAnimator);
Dianne Hackborn529e7442012-11-01 14:22:28 -0700735 }
736 if (displayAnimator.mScreenRotationAnimation != null) {
737 pw.print(subPrefix); pw.println("mScreenRotationAnimation:");
738 displayAnimator.mScreenRotationAnimation.printTo(subSubPrefix, pw);
739 } else if (dumpAll) {
740 pw.print(subPrefix); pw.println("no ScreenRotationAnimation ");
741 }
742 }
743
744 pw.println();
745
746 if (dumpAll) {
747 pw.print(prefix); pw.print("mAnimTransactionSequence=");
748 pw.print(mAnimTransactionSequence);
749 pw.print(" mForceHiding="); pw.println(forceHidingToString());
750 pw.print(prefix); pw.print("mCurrentTime=");
751 pw.println(TimeUtils.formatUptime(mCurrentTime));
Dianne Hackborn529e7442012-11-01 14:22:28 -0700752 }
753 if (mBulkUpdateParams != 0) {
754 pw.print(prefix); pw.print("mBulkUpdateParams=0x");
755 pw.print(Integer.toHexString(mBulkUpdateParams));
756 pw.println(bulkUpdateParamsToString(mBulkUpdateParams));
757 }
Dianne Hackborn529e7442012-11-01 14:22:28 -0700758 if (mWindowDetachedWallpaper != null) {
759 pw.print(prefix); pw.print("mWindowDetachedWallpaper=");
760 pw.println(mWindowDetachedWallpaper);
761 }
Dianne Hackborn529e7442012-11-01 14:22:28 -0700762 if (mUniverseBackground != null) {
763 pw.print(prefix); pw.print("mUniverseBackground="); pw.print(mUniverseBackground);
764 pw.print(" mAboveUniverseLayer="); pw.println(mAboveUniverseLayer);
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700765 }
Craig Mautnere7ae2502012-03-26 17:11:19 -0700766 }
Craig Mautnerbec53f72012-04-05 11:49:05 -0700767
Craig Mautner66f78d72012-12-04 16:46:50 -0800768 int getPendingLayoutChanges(final int displayId) {
769 return mService.getDisplayContentLocked(displayId).pendingLayoutChanges;
770 }
771
Craig Mautner76a71652012-09-03 23:23:58 -0700772 void setPendingLayoutChanges(final int displayId, final int changes) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800773 mService.getDisplayContentLocked(displayId).pendingLayoutChanges |= changes;
Craig Mautner76a71652012-09-03 23:23:58 -0700774 }
775
776 void setAppLayoutChanges(final AppWindowAnimator appAnimator, final int changes, String s) {
777 // Used to track which displays layout changes have been done.
778 SparseIntArray displays = new SparseIntArray();
Craig Mautner96868332012-12-04 14:29:11 -0800779 WindowList windows = appAnimator.mAppToken.allAppWindows;
780 for (int i = windows.size() - 1; i >= 0; i--) {
781 final int displayId = windows.get(i).getDisplayId();
Craig Mautner76a71652012-09-03 23:23:58 -0700782 if (displays.indexOfKey(displayId) < 0) {
783 setPendingLayoutChanges(displayId, changes);
784 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800785 mService.debugLayoutRepeats(s, getPendingLayoutChanges(displayId));
Craig Mautner76a71652012-09-03 23:23:58 -0700786 }
787 // Keep from processing this display again.
788 displays.put(displayId, changes);
789 }
790 }
Craig Mautner4d7349b2012-04-20 14:52:47 -0700791 }
Craig Mautnera91f9e22012-09-14 16:22:08 -0700792
Craig Mautner1420b932012-12-28 17:14:38 -0800793 void setDimWinAnimatorLocked(int displayId, WindowStateAnimator newWinAnimator) {
Craig Mautner96868332012-12-04 14:29:11 -0800794 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
Craig Mautner1420b932012-12-28 17:14:38 -0800795 if (newWinAnimator == null) {
796 displayAnimator.mDimWinAnimator = null;
Craig Mautner96868332012-12-04 14:29:11 -0800797 } else {
Craig Mautner96868332012-12-04 14:29:11 -0800798 // Only set dim params on the highest dimmed layer.
Craig Mautner1420b932012-12-28 17:14:38 -0800799 final WindowStateAnimator existingDimWinAnimator = displayAnimator.mDimWinAnimator;
800 // Don't turn on for an unshown surface, or for any layer but the highest dimmed layer.
Craig Mautner96868332012-12-04 14:29:11 -0800801 if (newWinAnimator.mSurfaceShown && (existingDimWinAnimator == null
802 || !existingDimWinAnimator.mSurfaceShown
803 || existingDimWinAnimator.mAnimLayer < newWinAnimator.mAnimLayer)) {
Craig Mautner1420b932012-12-28 17:14:38 -0800804 displayAnimator.mDimWinAnimator = newWinAnimator;
Craig Mautner96868332012-12-04 14:29:11 -0800805 }
806 }
807 }
808
Craig Mautnera91f9e22012-09-14 16:22:08 -0700809 private DisplayContentsAnimator getDisplayContentsAnimatorLocked(int displayId) {
810 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
811 if (displayAnimator == null) {
Craig Mautnerac439e52012-09-21 08:58:34 -0700812 displayAnimator = new DisplayContentsAnimator(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700813 mDisplayContentsAnimators.put(displayId, displayAnimator);
814 }
815 return displayAnimator;
816 }
817
818 void setScreenRotationAnimationLocked(int displayId, ScreenRotationAnimation animation) {
819 getDisplayContentsAnimatorLocked(displayId).mScreenRotationAnimation = animation;
820 }
821
822 ScreenRotationAnimation getScreenRotationAnimationLocked(int displayId) {
823 return getDisplayContentsAnimatorLocked(displayId).mScreenRotationAnimation;
824 }
825
Craig Mautnerac439e52012-09-21 08:58:34 -0700826 private class DisplayContentsAnimator {
Craig Mautner1420b932012-12-28 17:14:38 -0800827 DimLayer mDimAnimator = null;
828 WindowStateAnimator mDimWinAnimator = null;
829 DimLayer mWindowAnimationBackgroundSurface = null;
Craig Mautnera91f9e22012-09-14 16:22:08 -0700830 ScreenRotationAnimation mScreenRotationAnimation = null;
Craig Mautnerac439e52012-09-21 08:58:34 -0700831
832 public DisplayContentsAnimator(int displayId) {
Craig Mautner1420b932012-12-28 17:14:38 -0800833 mDimAnimator = new DimLayer(mService, displayId);
834 mWindowAnimationBackgroundSurface = new DimLayer(mService, displayId);
Craig Mautnerac439e52012-09-21 08:58:34 -0700835 }
Craig Mautnera91f9e22012-09-14 16:22:08 -0700836 }
Craig Mautner764983d2012-03-22 11:37:36 -0700837}