blob: d42221e4f087fec840e798378a624b40c7aa999b [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 Mautner66f78d72012-12-04 16:46:50 -080028import com.android.server.wm.WindowManagerService.DisplayContentsIterator;
Dianne Hackborn529e7442012-11-01 14:22:28 -070029import com.android.server.wm.WindowManagerService.LayoutFields;
Craig Mautner764983d2012-03-22 11:37:36 -070030
Craig Mautnere7ae2502012-03-26 17:11:19 -070031import java.io.PrintWriter;
Dianne Hackborn0c2acff2012-04-12 15:17:07 -070032import java.util.ArrayList;
Craig Mautnere7ae2502012-03-26 17:11:19 -070033
Craig Mautner764983d2012-03-22 11:37:36 -070034/**
Craig Mautner764983d2012-03-22 11:37:36 -070035 * Singleton class that carries out the animations and Surface operations in a separate task
36 * on behalf of WindowManagerService.
37 */
38public class WindowAnimator {
Craig Mautnerbb1449b2012-03-23 16:11:14 -070039 private static final String TAG = "WindowAnimator";
Craig Mautner764983d2012-03-22 11:37:36 -070040
Craig Mautner1420b932012-12-28 17:14:38 -080041 /** Amount of time in milliseconds to animate the dim surface from one value to another,
42 * when no window animation is driving it. */
43 static final int DEFAULT_DIM_DURATION = 200;
44
Craig Mautner764983d2012-03-22 11:37:36 -070045 final WindowManagerService mService;
46 final Context mContext;
47 final WindowManagerPolicy mPolicy;
48
49 boolean mAnimating;
Craig Mautner01cd0e72012-06-18 10:19:11 -070050
Craig Mautner1caa3992012-06-22 09:46:48 -070051 final Runnable mAnimationRunnable;
52
Craig Mautner764983d2012-03-22 11:37:36 -070053 int mAdjResult;
54
Craig Mautner764983d2012-03-22 11:37:36 -070055 /** Time of current animation step. Reset on each iteration */
56 long mCurrentTime;
57
58 /** Skip repeated AppWindowTokens initialization. Note that AppWindowsToken's version of this
59 * 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 -070060 private int mAnimTransactionSequence;
Craig Mautner764983d2012-03-22 11:37:36 -070061
Craig Mautnerae446592012-12-06 19:05:05 -080062 /** Window currently running an animation that has requested it be detached
63 * from the wallpaper. This means we need to ensure the wallpaper is
64 * visible behind it in case it animates in a way that would allow it to be
65 * seen. If multiple windows satisfy this, use the lowest window. */
Craig Mautnere7ae2502012-03-26 17:11:19 -070066 WindowState mWindowDetachedWallpaper = null;
Craig Mautner01cd0e72012-06-18 10:19:11 -070067
Dianne Hackborna4b7f2f2012-05-21 11:28:41 -070068 WindowStateAnimator mUniverseBackground = null;
69 int mAboveUniverseLayer = 0;
70
Craig Mautnera608b882012-03-30 13:03:49 -070071 int mBulkUpdateParams = 0;
72
Craig Mautnera91f9e22012-09-14 16:22:08 -070073 SparseArray<DisplayContentsAnimator> mDisplayContentsAnimators =
74 new SparseArray<WindowAnimator.DisplayContentsAnimator>();
Craig Mautnerd09cc4b2012-04-04 10:23:31 -070075
Craig Mautnerb47bbc32012-08-22 17:41:48 -070076 boolean mInitialized = false;
77
Craig Mautner178af592012-09-17 10:37:29 -070078 // forceHiding states.
79 static final int KEYGUARD_NOT_SHOWN = 0;
80 static final int KEYGUARD_ANIMATING_IN = 1;
81 static final int KEYGUARD_SHOWN = 2;
82 static final int KEYGUARD_ANIMATING_OUT = 3;
83 int mForceHiding = KEYGUARD_NOT_SHOWN;
84
85 private String forceHidingToString() {
86 switch (mForceHiding) {
87 case KEYGUARD_NOT_SHOWN: return "KEYGUARD_NOT_SHOWN";
88 case KEYGUARD_ANIMATING_IN: return "KEYGUARD_ANIMATING_IN";
89 case KEYGUARD_SHOWN: return "KEYGUARD_SHOWN";
90 case KEYGUARD_ANIMATING_OUT:return "KEYGUARD_ANIMATING_OUT";
91 default: return "KEYGUARD STATE UNKNOWN " + mForceHiding;
92 }
93 }
94
Craig Mautner918b53b2012-07-09 14:15:54 -070095 WindowAnimator(final WindowManagerService service) {
Craig Mautner764983d2012-03-22 11:37:36 -070096 mService = service;
Craig Mautner918b53b2012-07-09 14:15:54 -070097 mContext = service.mContext;
98 mPolicy = service.mPolicy;
Craig Mautner1caa3992012-06-22 09:46:48 -070099
100 mAnimationRunnable = new Runnable() {
101 @Override
102 public void run() {
Craig Mautner96868332012-12-04 14:29:11 -0800103 synchronized (mService.mWindowMap) {
104 mService.mAnimationScheduled = false;
105 animateLocked();
Craig Mautner1caa3992012-06-22 09:46:48 -0700106 }
107 }
108 };
Craig Mautnerb47bbc32012-08-22 17:41:48 -0700109 }
Craig Mautner9e809442012-06-22 17:13:04 -0700110
Craig Mautnera91f9e22012-09-14 16:22:08 -0700111 void addDisplayLocked(final int displayId) {
Craig Mautnerac439e52012-09-21 08:58:34 -0700112 // Create the DisplayContentsAnimator object by retrieving it.
113 getDisplayContentsAnimatorLocked(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700114 if (displayId == Display.DEFAULT_DISPLAY) {
115 mInitialized = true;
116 }
117 }
118
119 void removeDisplayLocked(final int displayId) {
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700120 final DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
121 if (displayAnimator != null) {
122 if (displayAnimator.mWindowAnimationBackgroundSurface != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800123 displayAnimator.mWindowAnimationBackgroundSurface.destroySurface();
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700124 displayAnimator.mWindowAnimationBackgroundSurface = null;
125 }
126 if (displayAnimator.mScreenRotationAnimation != null) {
127 displayAnimator.mScreenRotationAnimation.kill();
128 displayAnimator.mScreenRotationAnimation = null;
129 }
130 if (displayAnimator.mDimAnimator != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800131 displayAnimator.mDimAnimator.destroySurface();
Craig Mautnerd5523dc2012-10-02 13:49:22 -0700132 displayAnimator.mDimAnimator = null;
133 }
134 }
135
Craig Mautnera91f9e22012-09-14 16:22:08 -0700136 mDisplayContentsAnimators.delete(displayId);
Craig Mautner1caa3992012-06-22 09:46:48 -0700137 }
138
Craig Mautner96868332012-12-04 14:29:11 -0800139 AppWindowAnimator getWallpaperAppAnimator() {
140 return mService.mWallpaperTarget == null
141 ? null : mService.mWallpaperTarget.mAppToken == null
142 ? null : mService.mWallpaperTarget.mAppToken.mAppAnimator;
Craig Mautner711f90a2012-07-03 18:43:52 -0700143 }
144
Craig Mautner96868332012-12-04 14:29:11 -0800145 void hideWallpapersLocked(final WindowState w) {
146 final WindowState wallpaperTarget = mService.mWallpaperTarget;
147 final WindowState lowerWallpaperTarget = mService.mLowerWallpaperTarget;
148 final ArrayList<WindowToken> wallpaperTokens = mService.mWallpaperTokens;
Craig Mautner66f78d72012-12-04 16:46:50 -0800149
Dianne Hackborn98129732012-11-01 16:28:16 -0700150 if ((wallpaperTarget == w && lowerWallpaperTarget == null) || wallpaperTarget == null) {
151 final int numTokens = wallpaperTokens.size();
Craig Mautner918b53b2012-07-09 14:15:54 -0700152 for (int i = numTokens - 1; i >= 0; i--) {
Dianne Hackborn98129732012-11-01 16:28:16 -0700153 final WindowToken token = wallpaperTokens.get(i);
Craig Mautner918b53b2012-07-09 14:15:54 -0700154 final int numWindows = token.windows.size();
155 for (int j = numWindows - 1; j >= 0; j--) {
156 final WindowState wallpaper = token.windows.get(j);
Craig Mautnerb9836b92012-06-11 11:40:09 -0700157 final WindowStateAnimator winAnimator = wallpaper.mWinAnimator;
158 if (!winAnimator.mLastHidden) {
159 winAnimator.hide();
Craig Mautner507a2ee2012-06-13 08:39:38 -0700160 mService.dispatchWallpaperVisibility(wallpaper, false);
Craig Mautner76a71652012-09-03 23:23:58 -0700161 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
162 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnerb9836b92012-06-11 11:40:09 -0700163 }
164 }
Dianne Hackbornef03a7f2012-10-29 18:46:52 -0700165 if (WindowManagerService.DEBUG_WALLPAPER_LIGHT && !token.hidden) Slog.d(TAG,
Dianne Hackborn2ea9bae2012-11-02 18:43:48 -0700166 "Hiding wallpaper " + token + " from " + w
167 + " target=" + wallpaperTarget + " lower=" + lowerWallpaperTarget
168 + "\n" + Debug.getCallers(5, " "));
Craig Mautnerb9836b92012-06-11 11:40:09 -0700169 token.hidden = true;
Craig Mautner0afddcb2012-05-08 15:38:00 -0700170 }
Craig Mautner0afddcb2012-05-08 15:38:00 -0700171 }
172 }
173
Craig Mautnera91f9e22012-09-14 16:22:08 -0700174 private void updateAppWindowsLocked() {
Craig Mautner764983d2012-03-22 11:37:36 -0700175 int i;
Craig Mautner96868332012-12-04 14:29:11 -0800176 final ArrayList<AppWindowToken> appTokens = mService.mAnimatingAppTokens;
177 final int NAT = appTokens.size();
Craig Mautner764983d2012-03-22 11:37:36 -0700178 for (i=0; i<NAT; i++) {
Craig Mautner96868332012-12-04 14:29:11 -0800179 final AppWindowAnimator appAnimator = appTokens.get(i).mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700180 final boolean wasAnimating = appAnimator.animation != null
Craig Mautnerfbf378c2012-04-23 17:24:21 -0700181 && appAnimator.animation != AppWindowAnimator.sDummyAnimation;
Craig Mautner9339c402012-11-30 11:23:56 -0800182 if (appAnimator.stepAnimationLocked(mCurrentTime)) {
Craig Mautner764983d2012-03-22 11:37:36 -0700183 mAnimating = true;
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700184 } else if (wasAnimating) {
185 // stopped animating, do one more pass through the layout
Craig Mautner76a71652012-09-03 23:23:58 -0700186 setAppLayoutChanges(appAnimator, WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
187 "appToken " + appAnimator.mAppToken + " done");
Craig Mautner83339b42012-05-01 22:13:23 -0700188 if (WindowManagerService.DEBUG_ANIM) Slog.v(TAG,
189 "updateWindowsApps...: done animating " + appAnimator.mAppToken);
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700190 }
191 }
Craig Mautnera2c77052012-03-26 12:14:43 -0700192
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700193 final int NEAT = mService.mExitingAppTokens.size();
194 for (i=0; i<NEAT; i++) {
Craig Mautnere4d8a5d2012-04-05 13:10:37 -0700195 final AppWindowAnimator appAnimator = mService.mExitingAppTokens.get(i).mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700196 final boolean wasAnimating = appAnimator.animation != null
Craig Mautnerfbf378c2012-04-23 17:24:21 -0700197 && appAnimator.animation != AppWindowAnimator.sDummyAnimation;
Craig Mautner9339c402012-11-30 11:23:56 -0800198 if (appAnimator.stepAnimationLocked(mCurrentTime)) {
Craig Mautnerbb1449b2012-03-23 16:11:14 -0700199 mAnimating = true;
200 } else if (wasAnimating) {
201 // stopped animating, do one more pass through the layout
Craig Mautner76a71652012-09-03 23:23:58 -0700202 setAppLayoutChanges(appAnimator, WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
203 "exiting appToken " + appAnimator.mAppToken + " done");
Craig Mautner83339b42012-05-01 22:13:23 -0700204 if (WindowManagerService.DEBUG_ANIM) Slog.v(TAG,
205 "updateWindowsApps...: done animating exiting " + appAnimator.mAppToken);
Craig Mautner764983d2012-03-22 11:37:36 -0700206 }
207 }
Craig Mautner764983d2012-03-22 11:37:36 -0700208 }
209
Craig Mautnera91f9e22012-09-14 16:22:08 -0700210 private void updateWindowsLocked(final int displayId) {
Craig Mautner6fbda632012-07-03 09:26:39 -0700211 ++mAnimTransactionSequence;
Craig Mautner764983d2012-03-22 11:37:36 -0700212
Craig Mautner96868332012-12-04 14:29:11 -0800213 final WindowList windows = mService.getWindowListLocked(displayId);
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700214 ArrayList<WindowStateAnimator> unForceHiding = null;
215 boolean wallpaperInUnForceHiding = false;
Craig Mautner178af592012-09-17 10:37:29 -0700216 mForceHiding = KEYGUARD_NOT_SHOWN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700217
Craig Mautner96868332012-12-04 14:29:11 -0800218 for (int i = windows.size() - 1; i >= 0; i--) {
219 WindowState win = windows.get(i);
220 WindowStateAnimator winAnimator = win.mWinAnimator;
Craig Mautnerbec53f72012-04-05 11:49:05 -0700221 final int flags = winAnimator.mAttrFlags;
Craig Mautner764983d2012-03-22 11:37:36 -0700222
Craig Mautnerc2f9be02012-03-27 17:32:29 -0700223 if (winAnimator.mSurface != null) {
Craig Mautnera2c77052012-03-26 12:14:43 -0700224 final boolean wasAnimating = winAnimator.mWasAnimating;
225 final boolean nowAnimating = winAnimator.stepAnimationLocked(mCurrentTime);
Craig Mautner764983d2012-03-22 11:37:36 -0700226
227 if (WindowManagerService.DEBUG_WALLPAPER) {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700228 Slog.v(TAG, win + ": wasAnimating=" + wasAnimating +
Craig Mautner764983d2012-03-22 11:37:36 -0700229 ", nowAnimating=" + nowAnimating);
230 }
231
Craig Mautner96868332012-12-04 14:29:11 -0800232 if (wasAnimating && !winAnimator.mAnimating && mService.mWallpaperTarget == win) {
Craig Mautnera608b882012-03-30 13:03:49 -0700233 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
Craig Mautner76a71652012-09-03 23:23:58 -0700234 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
235 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700236 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700237 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 2",
Craig Mautner66f78d72012-12-04 16:46:50 -0800238 getPendingLayoutChanges(Display.DEFAULT_DISPLAY));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700239 }
Craig Mautner764983d2012-03-22 11:37:36 -0700240 }
241
Craig Mautnerbec53f72012-04-05 11:49:05 -0700242 if (mPolicy.doesForceHide(win, win.mAttrs)) {
Craig Mautner764983d2012-03-22 11:37:36 -0700243 if (!wasAnimating && nowAnimating) {
Craig Mautner83339b42012-05-01 22:13:23 -0700244 if (WindowManagerService.DEBUG_ANIM ||
245 WindowManagerService.DEBUG_VISIBILITY) Slog.v(TAG,
246 "Animation started that could impact force hide: " + win);
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700247 mBulkUpdateParams |= SET_FORCE_HIDING_CHANGED;
Craig Mautner76a71652012-09-03 23:23:58 -0700248 setPendingLayoutChanges(displayId,
249 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700250 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700251 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 3",
Craig Mautner66f78d72012-12-04 16:46:50 -0800252 getPendingLayoutChanges(displayId));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700253 }
Craig Mautner764983d2012-03-22 11:37:36 -0700254 mService.mFocusMayChange = true;
Dianne Hackbornac920872012-05-22 11:49:49 -0700255 }
Craig Mautner4bf18a72012-07-10 14:08:16 -0700256 if (win.isReadyForDisplay()) {
257 if (nowAnimating) {
258 if (winAnimator.mAnimationIsEntrance) {
Craig Mautner178af592012-09-17 10:37:29 -0700259 mForceHiding = KEYGUARD_ANIMATING_IN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700260 } else {
Craig Mautner178af592012-09-17 10:37:29 -0700261 mForceHiding = KEYGUARD_ANIMATING_OUT;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700262 }
263 } else {
Craig Mautner178af592012-09-17 10:37:29 -0700264 mForceHiding = KEYGUARD_SHOWN;
Craig Mautner4bf18a72012-07-10 14:08:16 -0700265 }
Craig Mautner764983d2012-03-22 11:37:36 -0700266 }
Dianne Hackbornac920872012-05-22 11:49:49 -0700267 if (WindowManagerService.DEBUG_VISIBILITY) Slog.v(TAG,
Craig Mautner178af592012-09-17 10:37:29 -0700268 "Force hide " + mForceHiding
Dianne Hackbornac920872012-05-22 11:49:49 -0700269 + " hasSurface=" + win.mHasSurface
270 + " policyVis=" + win.mPolicyVisibility
271 + " destroying=" + win.mDestroying
272 + " attHidden=" + win.mAttachedHidden
273 + " vis=" + win.mViewVisibility
274 + " hidden=" + win.mRootToken.hidden
275 + " anim=" + win.mWinAnimator.mAnimation);
Craig Mautnerbec53f72012-04-05 11:49:05 -0700276 } else if (mPolicy.canBeForceHidden(win, win.mAttrs)) {
Craig Mautner4bf18a72012-07-10 14:08:16 -0700277 final boolean hideWhenLocked =
278 (winAnimator.mAttrFlags & FLAG_SHOW_WHEN_LOCKED) == 0;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700279 final boolean changed;
Craig Mautner178af592012-09-17 10:37:29 -0700280 if (((mForceHiding == KEYGUARD_ANIMATING_IN)
Craig Mautner4bf18a72012-07-10 14:08:16 -0700281 && (!winAnimator.isAnimating() || hideWhenLocked))
Craig Mautner178af592012-09-17 10:37:29 -0700282 || ((mForceHiding == KEYGUARD_SHOWN) && hideWhenLocked)) {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700283 changed = win.hideLw(false, false);
Craig Mautner764983d2012-03-22 11:37:36 -0700284 if (WindowManagerService.DEBUG_VISIBILITY && changed) Slog.v(TAG,
Craig Mautnerbec53f72012-04-05 11:49:05 -0700285 "Now policy hidden: " + win);
Craig Mautner764983d2012-03-22 11:37:36 -0700286 } else {
Craig Mautnerbec53f72012-04-05 11:49:05 -0700287 changed = win.showLw(false, false);
Craig Mautner764983d2012-03-22 11:37:36 -0700288 if (WindowManagerService.DEBUG_VISIBILITY && changed) Slog.v(TAG,
Craig Mautnerbec53f72012-04-05 11:49:05 -0700289 "Now policy shown: " + win);
Craig Mautner764983d2012-03-22 11:37:36 -0700290 if (changed) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700291 if ((mBulkUpdateParams & SET_FORCE_HIDING_CHANGED) != 0
Craig Mautnerbec53f72012-04-05 11:49:05 -0700292 && win.isVisibleNow() /*w.isReadyForDisplay()*/) {
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700293 if (unForceHiding == null) {
294 unForceHiding = new ArrayList<WindowStateAnimator>();
295 }
296 unForceHiding.add(winAnimator);
Craig Mautner01cd0e72012-06-18 10:19:11 -0700297 if ((flags & FLAG_SHOW_WALLPAPER) != 0) {
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700298 wallpaperInUnForceHiding = true;
Craig Mautner764983d2012-03-22 11:37:36 -0700299 }
300 }
Craig Mautnerbec53f72012-04-05 11:49:05 -0700301 if (mCurrentFocus == null || mCurrentFocus.mLayer < win.mLayer) {
Craig Mautner764983d2012-03-22 11:37:36 -0700302 // We are showing on to of the current
303 // focus, so re-evaluate focus to make
304 // sure it is correct.
305 mService.mFocusMayChange = true;
306 }
307 }
308 }
Craig Mautner01cd0e72012-06-18 10:19:11 -0700309 if (changed && (flags & FLAG_SHOW_WALLPAPER) != 0) {
Craig Mautnera608b882012-03-30 13:03:49 -0700310 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
Craig Mautner76a71652012-09-03 23:23:58 -0700311 setPendingLayoutChanges(Display.DEFAULT_DISPLAY,
312 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER);
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700313 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700314 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 4",
Craig Mautner66f78d72012-12-04 16:46:50 -0800315 getPendingLayoutChanges(Display.DEFAULT_DISPLAY));
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700316 }
Craig Mautner764983d2012-03-22 11:37:36 -0700317 }
318 }
319 }
320
Craig Mautnerbec53f72012-04-05 11:49:05 -0700321 final AppWindowToken atoken = win.mAppToken;
Craig Mautner6fbda632012-07-03 09:26:39 -0700322 if (winAnimator.mDrawState == WindowStateAnimator.READY_TO_SHOW) {
323 if (atoken == null || atoken.allDrawn) {
324 if (winAnimator.performShowLocked()) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800325 setPendingLayoutChanges(displayId,
Craig Mautner76a71652012-09-03 23:23:58 -0700326 WindowManagerPolicy.FINISH_LAYOUT_REDO_ANIM);
Craig Mautner6fbda632012-07-03 09:26:39 -0700327 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
328 mService.debugLayoutRepeats("updateWindowsAndWallpaperLocked 5",
Craig Mautner66f78d72012-12-04 16:46:50 -0800329 getPendingLayoutChanges(displayId));
Craig Mautner764983d2012-03-22 11:37:36 -0700330 }
331 }
Craig Mautnercf8cbbe2012-03-25 21:54:36 -0700332 }
Craig Mautner764983d2012-03-22 11:37:36 -0700333 }
Craig Mautner322e4032012-07-13 13:35:20 -0700334 final AppWindowAnimator appAnimator = winAnimator.mAppAnimator;
Craig Mautner59431632012-04-04 11:56:44 -0700335 if (appAnimator != null && appAnimator.thumbnail != null) {
Craig Mautner6fbda632012-07-03 09:26:39 -0700336 if (appAnimator.thumbnailTransactionSeq != mAnimTransactionSequence) {
337 appAnimator.thumbnailTransactionSeq = mAnimTransactionSequence;
Craig Mautner59431632012-04-04 11:56:44 -0700338 appAnimator.thumbnailLayer = 0;
Dianne Hackborn8078d8c2012-03-20 11:11:26 -0700339 }
Craig Mautner59431632012-04-04 11:56:44 -0700340 if (appAnimator.thumbnailLayer < winAnimator.mAnimLayer) {
341 appAnimator.thumbnailLayer = winAnimator.mAnimLayer;
Dianne Hackborn8078d8c2012-03-20 11:11:26 -0700342 }
343 }
Craig Mautner764983d2012-03-22 11:37:36 -0700344 } // end forall windows
Dianne Hackborn0c2acff2012-04-12 15:17:07 -0700345
Craig Mautner078ea0a2012-06-25 11:04:29 -0700346 // If we have windows that are being show due to them no longer
347 // being force-hidden, apply the appropriate animation to them.
348 if (unForceHiding != null) {
349 for (int i=unForceHiding.size()-1; i>=0; i--) {
350 Animation a = mPolicy.createForceHideEnterAnimation(wallpaperInUnForceHiding);
351 if (a != null) {
352 final WindowStateAnimator winAnimator = unForceHiding.get(i);
353 winAnimator.setAnimation(a);
354 winAnimator.mAnimationIsEntrance = true;
355 }
356 }
357 }
358 }
359
Craig Mautnera91f9e22012-09-14 16:22:08 -0700360 private void updateWallpaperLocked(int displayId) {
361 final DisplayContentsAnimator displayAnimator =
362 getDisplayContentsAnimatorLocked(displayId);
Craig Mautner96868332012-12-04 14:29:11 -0800363 final WindowList windows = mService.getWindowListLocked(displayId);
Craig Mautner078ea0a2012-06-25 11:04:29 -0700364 WindowStateAnimator windowAnimationBackground = null;
365 int windowAnimationBackgroundColor = 0;
366 WindowState detachedWallpaper = null;
367
Craig Mautner96868332012-12-04 14:29:11 -0800368 for (int i = windows.size() - 1; i >= 0; i--) {
369 final WindowState win = windows.get(i);
370 WindowStateAnimator winAnimator = win.mWinAnimator;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700371 if (winAnimator.mSurface == null) {
372 continue;
373 }
374
375 final int flags = winAnimator.mAttrFlags;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700376
377 // If this window is animating, make a note that we have
378 // an animating window and take care of a request to run
379 // a detached wallpaper animation.
380 if (winAnimator.mAnimating) {
381 if (winAnimator.mAnimation != null) {
382 if ((flags & FLAG_SHOW_WALLPAPER) != 0
383 && winAnimator.mAnimation.getDetachWallpaper()) {
384 detachedWallpaper = win;
385 }
386 final int backgroundColor = winAnimator.mAnimation.getBackgroundColor();
387 if (backgroundColor != 0) {
388 if (windowAnimationBackground == null || (winAnimator.mAnimLayer <
389 windowAnimationBackground.mAnimLayer)) {
390 windowAnimationBackground = winAnimator;
391 windowAnimationBackgroundColor = backgroundColor;
392 }
393 }
394 }
395 mAnimating = true;
396 }
397
398 // If this window's app token is running a detached wallpaper
399 // animation, make a note so we can ensure the wallpaper is
400 // displayed behind it.
Craig Mautner322e4032012-07-13 13:35:20 -0700401 final AppWindowAnimator appAnimator = winAnimator.mAppAnimator;
Craig Mautner078ea0a2012-06-25 11:04:29 -0700402 if (appAnimator != null && appAnimator.animation != null
403 && appAnimator.animating) {
404 if ((flags & FLAG_SHOW_WALLPAPER) != 0
405 && appAnimator.animation.getDetachWallpaper()) {
406 detachedWallpaper = win;
407 }
408
409 final int backgroundColor = appAnimator.animation.getBackgroundColor();
410 if (backgroundColor != 0) {
411 if (windowAnimationBackground == null || (winAnimator.mAnimLayer <
412 windowAnimationBackground.mAnimLayer)) {
413 windowAnimationBackground = winAnimator;
414 windowAnimationBackgroundColor = backgroundColor;
415 }
416 }
417 }
418 } // end forall windows
419
Craig Mautner9e809442012-06-22 17:13:04 -0700420 if (mWindowDetachedWallpaper != detachedWallpaper) {
421 if (WindowManagerService.DEBUG_WALLPAPER) Slog.v(TAG,
422 "Detached wallpaper changed from " + mWindowDetachedWallpaper
423 + " to " + detachedWallpaper);
424 mWindowDetachedWallpaper = detachedWallpaper;
425 mBulkUpdateParams |= SET_WALLPAPER_MAY_CHANGE;
426 }
427
428 if (windowAnimationBackgroundColor != 0) {
429 // If the window that wants black is the current wallpaper
430 // target, then the black goes *below* the wallpaper so we
431 // don't cause the wallpaper to suddenly disappear.
432 int animLayer = windowAnimationBackground.mAnimLayer;
433 WindowState win = windowAnimationBackground.mWin;
Craig Mautner96868332012-12-04 14:29:11 -0800434 if (mService.mWallpaperTarget == win || mService.mLowerWallpaperTarget == win
435 || mService.mUpperWallpaperTarget == win) {
436 final int N = windows.size();
Craig Mautner9e809442012-06-22 17:13:04 -0700437 for (int i = 0; i < N; i++) {
Craig Mautner96868332012-12-04 14:29:11 -0800438 WindowStateAnimator winAnimator = windows.get(i).mWinAnimator;
Craig Mautner918b53b2012-07-09 14:15:54 -0700439 if (winAnimator.mIsWallpaper) {
Craig Mautner9e809442012-06-22 17:13:04 -0700440 animLayer = winAnimator.mAnimLayer;
441 break;
442 }
443 }
444 }
445
Craig Mautner1420b932012-12-28 17:14:38 -0800446 displayAnimator.mWindowAnimationBackgroundSurface.show(
447 animLayer - WindowManagerService.LAYER_OFFSET_DIM,
448 ((windowAnimationBackgroundColor >> 24) & 0xff) / 255f, 0);
Craig Mautner9e809442012-06-22 17:13:04 -0700449 } else {
Craig Mautner1420b932012-12-28 17:14:38 -0800450 displayAnimator.mWindowAnimationBackgroundSurface.hide();
Craig Mautner9e809442012-06-22 17:13:04 -0700451 }
Craig Mautner764983d2012-03-22 11:37:36 -0700452 }
453
Craig Mautner9339c402012-11-30 11:23:56 -0800454 /** See if any windows have been drawn, so they (and others associated with them) can now be
455 * shown. */
Craig Mautner764983d2012-03-22 11:37:36 -0700456 private void testTokenMayBeDrawnLocked() {
Craig Mautner96868332012-12-04 14:29:11 -0800457 // See if any windows have been drawn, so they (and others
458 // associated with them) can now be shown.
459 final ArrayList<AppWindowToken> appTokens = mService.mAnimatingAppTokens;
460 final int NT = appTokens.size();
Craig Mautner764983d2012-03-22 11:37:36 -0700461 for (int i=0; i<NT; i++) {
Craig Mautner96868332012-12-04 14:29:11 -0800462 AppWindowToken wtoken = appTokens.get(i);
463 AppWindowAnimator appAnimator = wtoken.mAppAnimator;
Craig Mautner6fbda632012-07-03 09:26:39 -0700464 final boolean allDrawn = wtoken.allDrawn;
Craig Mautner322e4032012-07-13 13:35:20 -0700465 if (allDrawn != appAnimator.allDrawn) {
466 appAnimator.allDrawn = allDrawn;
Craig Mautner6fbda632012-07-03 09:26:39 -0700467 if (allDrawn) {
468 // The token has now changed state to having all
469 // windows shown... what to do, what to do?
Craig Mautner322e4032012-07-13 13:35:20 -0700470 if (appAnimator.freezingScreen) {
471 appAnimator.showAllWindowsLocked();
Craig Mautner6fbda632012-07-03 09:26:39 -0700472 mService.unsetAppFreezingScreenLocked(wtoken, false, true);
473 if (WindowManagerService.DEBUG_ORIENTATION) Slog.i(TAG,
474 "Setting mOrientationChangeComplete=true because wtoken "
475 + wtoken + " numInteresting=" + wtoken.numInterestingWindows
476 + " numDrawn=" + wtoken.numDrawnWindows);
477 // This will set mOrientationChangeComplete and cause a pass through layout.
Craig Mautner76a71652012-09-03 23:23:58 -0700478 setAppLayoutChanges(appAnimator,
479 WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER,
480 "testTokenMayBeDrawnLocked: freezingScreen");
Craig Mautner6fbda632012-07-03 09:26:39 -0700481 } else {
Craig Mautner76a71652012-09-03 23:23:58 -0700482 setAppLayoutChanges(appAnimator,
483 WindowManagerPolicy.FINISH_LAYOUT_REDO_ANIM,
484 "testTokenMayBeDrawnLocked");
Craig Mautner66f78d72012-12-04 16:46:50 -0800485
Craig Mautner6fbda632012-07-03 09:26:39 -0700486 // We can now show all of the drawn windows!
487 if (!mService.mOpeningApps.contains(wtoken)) {
Craig Mautner322e4032012-07-13 13:35:20 -0700488 mAnimating |= appAnimator.showAllWindowsLocked();
Craig Mautner6fbda632012-07-03 09:26:39 -0700489 }
Craig Mautner764983d2012-03-22 11:37:36 -0700490 }
491 }
492 }
493 }
494 }
495
Craig Mautnera91f9e22012-09-14 16:22:08 -0700496 private void performAnimationsLocked(final int displayId) {
497 updateWindowsLocked(displayId);
498 updateWallpaperLocked(displayId);
Craig Mautner764983d2012-03-22 11:37:36 -0700499 }
500
Craig Mautner1420b932012-12-28 17:14:38 -0800501 private long getDimBehindFadeDuration(long duration) {
502 TypedValue tv = new TypedValue();
503 mContext.getResources().getValue(
504 com.android.internal.R.fraction.config_dimBehindFadeDuration, tv, true);
505 if (tv.type == TypedValue.TYPE_FRACTION) {
506 duration = (long)tv.getFraction(duration, duration);
507 } else if (tv.type >= TypedValue.TYPE_FIRST_INT && tv.type <= TypedValue.TYPE_LAST_INT) {
508 duration = tv.data;
509 }
510 return duration;
511 }
512
513 /** Locked on mService.mWindowMap. */
Craig Mautner1caa3992012-06-22 09:46:48 -0700514 private void animateLocked() {
Craig Mautnerb47bbc32012-08-22 17:41:48 -0700515 if (!mInitialized) {
516 return;
517 }
Craig Mautner59c00972012-07-30 12:10:24 -0700518
Craig Mautner764983d2012-03-22 11:37:36 -0700519 mCurrentTime = SystemClock.uptimeMillis();
Craig Mautner2639da52012-07-09 09:39:06 -0700520 mBulkUpdateParams = SET_ORIENTATION_CHANGE_COMPLETE;
Chet Haase198e5642012-05-10 09:55:15 -0700521 boolean wasAnimating = mAnimating;
Craig Mautner7d8df392012-04-06 15:26:23 -0700522 mAnimating = false;
523 if (WindowManagerService.DEBUG_WINDOW_TRACE) {
524 Slog.i(TAG, "!!! animate: entry time=" + mCurrentTime);
525 }
Craig Mautner764983d2012-03-22 11:37:36 -0700526
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700527 if (WindowManagerService.SHOW_TRANSACTIONS) Slog.i(
528 TAG, ">>> OPEN TRANSACTION animateLocked");
Craig Mautner764983d2012-03-22 11:37:36 -0700529 Surface.openTransaction();
Jamie Gennisb6ce6e42012-10-15 19:14:58 -0700530 Surface.setAnimationTransaction();
Craig Mautner764983d2012-03-22 11:37:36 -0700531 try {
Craig Mautnera91f9e22012-09-14 16:22:08 -0700532 updateAppWindowsLocked();
Craig Mautner764983d2012-03-22 11:37:36 -0700533
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);
537 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
538
539 final ScreenRotationAnimation screenRotationAnimation =
540 displayAnimator.mScreenRotationAnimation;
541 if (screenRotationAnimation != null && screenRotationAnimation.isAnimating()) {
542 if (screenRotationAnimation.stepAnimationLocked(mCurrentTime)) {
543 mAnimating = true;
544 } else {
545 mBulkUpdateParams |= SET_UPDATE_ROTATION;
546 screenRotationAnimation.kill();
547 displayAnimator.mScreenRotationAnimation = null;
548 }
549 }
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700550
551 // Update animations of all applications, including those
552 // associated with exiting/removed apps
Craig Mautnera91f9e22012-09-14 16:22:08 -0700553 performAnimationsLocked(displayId);
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700554
Craig Mautner96868332012-12-04 14:29:11 -0800555 final WindowList windows = mService.getWindowListLocked(displayId);
556 final int N = windows.size();
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700557 for (int j = 0; j < N; j++) {
Craig Mautner96868332012-12-04 14:29:11 -0800558 windows.get(j).mWinAnimator.prepareSurfaceLocked(true);
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700559 }
560 }
561
562 testTokenMayBeDrawnLocked();
Craig Mautner764983d2012-03-22 11:37:36 -0700563
Craig Mautnera91f9e22012-09-14 16:22:08 -0700564 for (int i = 0; i < numDisplays; i++) {
565 final int displayId = mDisplayContentsAnimators.keyAt(i);
566 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
Craig Mautner764983d2012-03-22 11:37:36 -0700567
Craig Mautnera91f9e22012-09-14 16:22:08 -0700568 final ScreenRotationAnimation screenRotationAnimation =
569 displayAnimator.mScreenRotationAnimation;
570 if (screenRotationAnimation != null) {
571 screenRotationAnimation.updateSurfacesInTransaction();
572 }
573
Craig Mautner1420b932012-12-28 17:14:38 -0800574 final DimLayer dimAnimator = displayAnimator.mDimAnimator;
575 final WindowStateAnimator winAnimator = displayAnimator.mDimWinAnimator;
Craig Mautner13131e72013-01-11 11:03:33 -0800576 final int dimLayer;
Craig Mautner1420b932012-12-28 17:14:38 -0800577 final float dimAmount;
578 if (winAnimator == null) {
Craig Mautner13131e72013-01-11 11:03:33 -0800579 dimLayer = dimAnimator.getLayer();
Craig Mautner1420b932012-12-28 17:14:38 -0800580 dimAmount = 0;
581 } else {
Craig Mautner13131e72013-01-11 11:03:33 -0800582 dimLayer = winAnimator.mAnimLayer - WindowManagerService.LAYER_OFFSET_DIM;
Craig Mautner1420b932012-12-28 17:14:38 -0800583 dimAmount = winAnimator.mWin.mAttrs.dimAmount;
Craig Mautnera91f9e22012-09-14 16:22:08 -0700584 }
Craig Mautner1420b932012-12-28 17:14:38 -0800585 final float targetAlpha = dimAnimator.getTargetAlpha();
586 if (targetAlpha != dimAmount) {
587 if (winAnimator == null) {
588 dimAnimator.hide(DEFAULT_DIM_DURATION);
589 } else {
590 long duration = (winAnimator.mAnimating && winAnimator.mAnimation != null)
591 ? winAnimator.mAnimation.computeDurationHint()
592 : DEFAULT_DIM_DURATION;
593 if (targetAlpha > dimAmount) {
594 duration = getDimBehindFadeDuration(duration);
595 }
Craig Mautner13131e72013-01-11 11:03:33 -0800596 dimAnimator.show(dimLayer, dimAmount, duration);
Craig Mautner1420b932012-12-28 17:14:38 -0800597 }
Craig Mautner13131e72013-01-11 11:03:33 -0800598 } else if (dimAnimator.getLayer() != dimLayer) {
599 dimAnimator.setLayer(dimLayer);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700600 }
Craig Mautner1420b932012-12-28 17:14:38 -0800601 if (dimAnimator.isAnimating()) {
602 if (!mService.okToDisplay()) {
603 // Jump to the end of the animation.
604 dimAnimator.show();
605 } else {
606 mAnimating |= dimAnimator.stepAnimation();
607 }
608 }
609
Svetoslav Ganov545252f2012-12-10 18:29:24 -0800610 //TODO (multidisplay): Magnification is supported only for the default display.
611 if (mService.mDisplayMagnifier != null && displayId == Display.DEFAULT_DISPLAY) {
612 mService.mDisplayMagnifier.drawMagnifiedRegionBorderIfNeededLocked();
613 }
Craig Mautner764983d2012-03-22 11:37:36 -0700614 }
615
Craig Mautner7358fbf2012-04-12 21:06:33 -0700616 if (mService.mWatermark != null) {
617 mService.mWatermark.drawIfNeeded();
618 }
Craig Mautner764983d2012-03-22 11:37:36 -0700619 } catch (RuntimeException e) {
620 Log.wtf(TAG, "Unhandled exception in Window Manager", e);
621 } finally {
622 Surface.closeTransaction();
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700623 if (WindowManagerService.SHOW_TRANSACTIONS) Slog.i(
624 TAG, "<<< CLOSE TRANSACTION animateLocked");
625 }
626
Craig Mautner66f78d72012-12-04 16:46:50 -0800627 boolean hasPendingLayoutChanges = false;
628 DisplayContentsIterator iterator = mService.new DisplayContentsIterator();
629 while (iterator.hasNext()) {
630 final DisplayContent displayContent = iterator.next();
631 final int pendingChanges = getPendingLayoutChanges(displayContent.getDisplayId());
632 if ((pendingChanges & WindowManagerPolicy.FINISH_LAYOUT_REDO_WALLPAPER) != 0) {
Craig Mautner96868332012-12-04 14:29:11 -0800633 mBulkUpdateParams |= SET_WALLPAPER_ACTION_PENDING;
Craig Mautnerea3a09a2012-09-04 09:49:35 -0700634 }
Craig Mautner66f78d72012-12-04 16:46:50 -0800635 if (pendingChanges != 0) {
636 hasPendingLayoutChanges = true;
637 }
Craig Mautner764983d2012-03-22 11:37:36 -0700638 }
Craig Mautnerc2f9be02012-03-27 17:32:29 -0700639
Craig Mautner66f78d72012-12-04 16:46:50 -0800640 boolean doRequest = false;
641 if (mBulkUpdateParams != 0) {
642 doRequest = mService.copyAnimToLayoutParamsLocked();
643 }
644
645 if (hasPendingLayoutChanges || doRequest) {
646 mService.requestTraversalLocked();
Craig Mautner01cd0e72012-06-18 10:19:11 -0700647 }
Craig Mautner7d8df392012-04-06 15:26:23 -0700648
649 if (mAnimating) {
Craig Mautner96868332012-12-04 14:29:11 -0800650 mService.scheduleAnimationLocked();
Chet Haase198e5642012-05-10 09:55:15 -0700651 } else if (wasAnimating) {
652 mService.requestTraversalLocked();
Craig Mautner7d8df392012-04-06 15:26:23 -0700653 }
654 if (WindowManagerService.DEBUG_WINDOW_TRACE) {
655 Slog.i(TAG, "!!! animate: exit mAnimating=" + mAnimating
656 + " mBulkUpdateParams=" + Integer.toHexString(mBulkUpdateParams)
Craig Mautner76a71652012-09-03 23:23:58 -0700657 + " mPendingLayoutChanges(DEFAULT_DISPLAY)="
Craig Mautner66f78d72012-12-04 16:46:50 -0800658 + Integer.toHexString(getPendingLayoutChanges(Display.DEFAULT_DISPLAY)));
Craig Mautner7d8df392012-04-06 15:26:23 -0700659 }
Craig Mautner764983d2012-03-22 11:37:36 -0700660 }
661
662 WindowState mCurrentFocus;
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700663 void setCurrentFocus(final WindowState currentFocus) {
Craig Mautner764983d2012-03-22 11:37:36 -0700664 mCurrentFocus = currentFocus;
665 }
666
Craig Mautnera91f9e22012-09-14 16:22:08 -0700667 boolean isDimmingLocked(int displayId) {
Craig Mautner1420b932012-12-28 17:14:38 -0800668 return getDisplayContentsAnimatorLocked(displayId).mDimAnimator.isDimming();
Craig Mautnerf8d4fbb2012-04-11 09:25:53 -0700669 }
670
Craig Mautnera91f9e22012-09-14 16:22:08 -0700671 boolean isDimmingLocked(final WindowStateAnimator winAnimator) {
Craig Mautner1420b932012-12-28 17:14:38 -0800672 final int displayId = winAnimator.mWin.getDisplayId();
673 DisplayContentsAnimator displayAnimator =
674 getDisplayContentsAnimatorLocked(displayId);
675 if (displayAnimator != null) {
676 return displayAnimator.mDimWinAnimator == winAnimator
677 && displayAnimator.mDimAnimator.isDimming();
678 }
679 return false;
Craig Mautneracafd192012-05-10 10:41:02 -0700680 }
681
Dianne Hackborn529e7442012-11-01 14:22:28 -0700682 static String bulkUpdateParamsToString(int bulkUpdateParams) {
683 StringBuilder builder = new StringBuilder(128);
684 if ((bulkUpdateParams & LayoutFields.SET_UPDATE_ROTATION) != 0) {
685 builder.append(" UPDATE_ROTATION");
686 }
687 if ((bulkUpdateParams & LayoutFields.SET_WALLPAPER_MAY_CHANGE) != 0) {
688 builder.append(" WALLPAPER_MAY_CHANGE");
689 }
690 if ((bulkUpdateParams & LayoutFields.SET_FORCE_HIDING_CHANGED) != 0) {
691 builder.append(" FORCE_HIDING_CHANGED");
692 }
693 if ((bulkUpdateParams & LayoutFields.SET_ORIENTATION_CHANGE_COMPLETE) != 0) {
694 builder.append(" ORIENTATION_CHANGE_COMPLETE");
695 }
696 if ((bulkUpdateParams & LayoutFields.SET_TURN_ON_SCREEN) != 0) {
697 builder.append(" TURN_ON_SCREEN");
698 }
699 return builder.toString();
700 }
701
Craig Mautnera91f9e22012-09-14 16:22:08 -0700702 public void dumpLocked(PrintWriter pw, String prefix, boolean dumpAll) {
Dianne Hackborn529e7442012-11-01 14:22:28 -0700703 final String subPrefix = " " + prefix;
704 final String subSubPrefix = " " + subPrefix;
705
Dianne Hackborn529e7442012-11-01 14:22:28 -0700706 for (int i = 0; i < mDisplayContentsAnimators.size(); i++) {
707 pw.print(prefix); pw.print("DisplayContentsAnimator #");
708 pw.print(mDisplayContentsAnimators.keyAt(i));
709 pw.println(":");
710 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.valueAt(i);
Craig Mautner96868332012-12-04 14:29:11 -0800711 final WindowList windows =
712 mService.getWindowListLocked(mDisplayContentsAnimators.keyAt(i));
713 final int N = windows.size();
714 for (int j = 0; j < N; j++) {
715 WindowStateAnimator wanim = windows.get(j).mWinAnimator;
Dianne Hackborn529e7442012-11-01 14:22:28 -0700716 pw.print(subPrefix); pw.print("Window #"); pw.print(j);
717 pw.print(": "); pw.println(wanim);
718 }
719 if (displayAnimator.mWindowAnimationBackgroundSurface != null) {
Craig Mautner1420b932012-12-28 17:14:38 -0800720 if (dumpAll || displayAnimator.mWindowAnimationBackgroundSurface.isDimming()) {
Dianne Hackborn529e7442012-11-01 14:22:28 -0700721 pw.print(subPrefix); pw.println("mWindowAnimationBackgroundSurface:");
Craig Mautnera91f9e22012-09-14 16:22:08 -0700722 displayAnimator.mWindowAnimationBackgroundSurface.printTo(subSubPrefix, pw);
723 }
Craig Mautner6fbda632012-07-03 09:26:39 -0700724 }
Craig Mautner1420b932012-12-28 17:14:38 -0800725 if (dumpAll || displayAnimator.mDimAnimator.isDimming()) {
726 pw.print(subPrefix); pw.println("mDimAnimator:");
727 displayAnimator.mDimAnimator.printTo(subSubPrefix, pw);
728 pw.print(subPrefix); pw.print("mDimWinAnimator=");
729 pw.println(displayAnimator.mDimWinAnimator);
Dianne Hackborn529e7442012-11-01 14:22:28 -0700730 }
731 if (displayAnimator.mScreenRotationAnimation != null) {
732 pw.print(subPrefix); pw.println("mScreenRotationAnimation:");
733 displayAnimator.mScreenRotationAnimation.printTo(subSubPrefix, pw);
734 } else if (dumpAll) {
735 pw.print(subPrefix); pw.println("no ScreenRotationAnimation ");
736 }
737 }
738
739 pw.println();
740
741 if (dumpAll) {
742 pw.print(prefix); pw.print("mAnimTransactionSequence=");
743 pw.print(mAnimTransactionSequence);
744 pw.print(" mForceHiding="); pw.println(forceHidingToString());
745 pw.print(prefix); pw.print("mCurrentTime=");
746 pw.println(TimeUtils.formatUptime(mCurrentTime));
Dianne Hackborn529e7442012-11-01 14:22:28 -0700747 }
748 if (mBulkUpdateParams != 0) {
749 pw.print(prefix); pw.print("mBulkUpdateParams=0x");
750 pw.print(Integer.toHexString(mBulkUpdateParams));
751 pw.println(bulkUpdateParamsToString(mBulkUpdateParams));
752 }
Dianne Hackborn529e7442012-11-01 14:22:28 -0700753 if (mWindowDetachedWallpaper != null) {
754 pw.print(prefix); pw.print("mWindowDetachedWallpaper=");
755 pw.println(mWindowDetachedWallpaper);
756 }
Dianne Hackborn529e7442012-11-01 14:22:28 -0700757 if (mUniverseBackground != null) {
758 pw.print(prefix); pw.print("mUniverseBackground="); pw.print(mUniverseBackground);
759 pw.print(" mAboveUniverseLayer="); pw.println(mAboveUniverseLayer);
Craig Mautnerd09cc4b2012-04-04 10:23:31 -0700760 }
Craig Mautnere7ae2502012-03-26 17:11:19 -0700761 }
Craig Mautnerbec53f72012-04-05 11:49:05 -0700762
Craig Mautner66f78d72012-12-04 16:46:50 -0800763 int getPendingLayoutChanges(final int displayId) {
764 return mService.getDisplayContentLocked(displayId).pendingLayoutChanges;
765 }
766
Craig Mautner76a71652012-09-03 23:23:58 -0700767 void setPendingLayoutChanges(final int displayId, final int changes) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800768 mService.getDisplayContentLocked(displayId).pendingLayoutChanges |= changes;
Craig Mautner76a71652012-09-03 23:23:58 -0700769 }
770
771 void setAppLayoutChanges(final AppWindowAnimator appAnimator, final int changes, String s) {
772 // Used to track which displays layout changes have been done.
773 SparseIntArray displays = new SparseIntArray();
Craig Mautner96868332012-12-04 14:29:11 -0800774 WindowList windows = appAnimator.mAppToken.allAppWindows;
775 for (int i = windows.size() - 1; i >= 0; i--) {
776 final int displayId = windows.get(i).getDisplayId();
Craig Mautner76a71652012-09-03 23:23:58 -0700777 if (displays.indexOfKey(displayId) < 0) {
778 setPendingLayoutChanges(displayId, changes);
779 if (WindowManagerService.DEBUG_LAYOUT_REPEATS) {
Craig Mautner66f78d72012-12-04 16:46:50 -0800780 mService.debugLayoutRepeats(s, getPendingLayoutChanges(displayId));
Craig Mautner76a71652012-09-03 23:23:58 -0700781 }
782 // Keep from processing this display again.
783 displays.put(displayId, changes);
784 }
785 }
Craig Mautner4d7349b2012-04-20 14:52:47 -0700786 }
Craig Mautnera91f9e22012-09-14 16:22:08 -0700787
Craig Mautner1420b932012-12-28 17:14:38 -0800788 void setDimWinAnimatorLocked(int displayId, WindowStateAnimator newWinAnimator) {
Craig Mautner96868332012-12-04 14:29:11 -0800789 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
Craig Mautner1420b932012-12-28 17:14:38 -0800790 if (newWinAnimator == null) {
791 displayAnimator.mDimWinAnimator = null;
Craig Mautner96868332012-12-04 14:29:11 -0800792 } else {
Craig Mautner96868332012-12-04 14:29:11 -0800793 // Only set dim params on the highest dimmed layer.
Craig Mautner1420b932012-12-28 17:14:38 -0800794 final WindowStateAnimator existingDimWinAnimator = displayAnimator.mDimWinAnimator;
795 // Don't turn on for an unshown surface, or for any layer but the highest dimmed layer.
Craig Mautner96868332012-12-04 14:29:11 -0800796 if (newWinAnimator.mSurfaceShown && (existingDimWinAnimator == null
797 || !existingDimWinAnimator.mSurfaceShown
798 || existingDimWinAnimator.mAnimLayer < newWinAnimator.mAnimLayer)) {
Craig Mautner1420b932012-12-28 17:14:38 -0800799 displayAnimator.mDimWinAnimator = newWinAnimator;
Craig Mautner96868332012-12-04 14:29:11 -0800800 }
801 }
802 }
803
Craig Mautnera91f9e22012-09-14 16:22:08 -0700804 private DisplayContentsAnimator getDisplayContentsAnimatorLocked(int displayId) {
805 DisplayContentsAnimator displayAnimator = mDisplayContentsAnimators.get(displayId);
806 if (displayAnimator == null) {
Craig Mautnerac439e52012-09-21 08:58:34 -0700807 displayAnimator = new DisplayContentsAnimator(displayId);
Craig Mautnera91f9e22012-09-14 16:22:08 -0700808 mDisplayContentsAnimators.put(displayId, displayAnimator);
809 }
810 return displayAnimator;
811 }
812
813 void setScreenRotationAnimationLocked(int displayId, ScreenRotationAnimation animation) {
814 getDisplayContentsAnimatorLocked(displayId).mScreenRotationAnimation = animation;
815 }
816
817 ScreenRotationAnimation getScreenRotationAnimationLocked(int displayId) {
818 return getDisplayContentsAnimatorLocked(displayId).mScreenRotationAnimation;
819 }
820
Craig Mautnerac439e52012-09-21 08:58:34 -0700821 private class DisplayContentsAnimator {
Craig Mautner1420b932012-12-28 17:14:38 -0800822 DimLayer mDimAnimator = null;
823 WindowStateAnimator mDimWinAnimator = null;
824 DimLayer mWindowAnimationBackgroundSurface = null;
Craig Mautnera91f9e22012-09-14 16:22:08 -0700825 ScreenRotationAnimation mScreenRotationAnimation = null;
Craig Mautnerac439e52012-09-21 08:58:34 -0700826
827 public DisplayContentsAnimator(int displayId) {
Craig Mautner1420b932012-12-28 17:14:38 -0800828 mDimAnimator = new DimLayer(mService, displayId);
829 mWindowAnimationBackgroundSurface = new DimLayer(mService, displayId);
Craig Mautnerac439e52012-09-21 08:58:34 -0700830 }
Craig Mautnera91f9e22012-09-14 16:22:08 -0700831 }
Craig Mautner764983d2012-03-22 11:37:36 -0700832}