WindowState.java revision f809870f118663055dc0f8b626204e7bb1133fb5
16e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn/*
26e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * Copyright (C) 2011 The Android Open Source Project
36e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn *
46e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * Licensed under the Apache License, Version 2.0 (the "License");
56e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * you may not use this file except in compliance with the License.
66e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * You may obtain a copy of the License at
76e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn *
86e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn *      http://www.apache.org/licenses/LICENSE-2.0
96e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn *
106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * Unless required by applicable law or agreed to in writing, software
116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * distributed under the License is distributed on an "AS IS" BASIS,
126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * See the License for the specific language governing permissions and
146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * limitations under the License.
156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn */
166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornpackage com.android.server.wm;
186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.FIRST_SUB_WINDOW;
206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.FLAG_COMPATIBLE_WINDOW;
216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.LAST_SUB_WINDOW;
226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.TYPE_APPLICATION_STARTING;
236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.TYPE_INPUT_METHOD;
246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.TYPE_INPUT_METHOD_DIALOG;
256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport static android.view.WindowManager.LayoutParams.TYPE_WALLPAPER;
266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport com.android.server.wm.WindowManagerService.H;
286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.content.res.Configuration;
306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.graphics.Matrix;
316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.graphics.PixelFormat;
326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.graphics.Rect;
33d040edbae968d826aa2c82d382345811a45c646bDianne Hackbornimport android.graphics.RectF;
346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.graphics.Region;
356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.os.IBinder;
366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.os.RemoteException;
376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.util.Slog;
386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.Gravity;
396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.IApplicationToken;
406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.IWindow;
416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.InputChannel;
426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.Surface;
436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.View;
446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.ViewTreeObserver;
456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.WindowManager;
466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.WindowManagerPolicy;
476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.WindowManager.LayoutParams;
486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.animation.Animation;
496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport android.view.animation.Transformation;
506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport java.io.PrintWriter;
526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornimport java.util.ArrayList;
536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn/**
556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn * A window in the window manager.
566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn */
576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackbornfinal class WindowState implements WindowManagerPolicy.WindowState {
585fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn    static final boolean DEBUG_VISIBILITY = WindowManagerService.DEBUG_VISIBILITY;
595fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn    static final boolean SHOW_TRANSACTIONS = WindowManagerService.SHOW_TRANSACTIONS;
605fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn    static final boolean SHOW_SURFACE_ALLOC = WindowManagerService.SHOW_SURFACE_ALLOC;
615fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn
626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final WindowManagerService mService;
636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Session mSession;
646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final IWindow mClient;
656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    WindowToken mToken;
666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    WindowToken mRootToken;
676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    AppWindowToken mAppToken;
686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    AppWindowToken mTargetAppToken;
696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final WindowManager.LayoutParams mAttrs = new WindowManager.LayoutParams();
706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final DeathRecipient mDeathRecipient;
716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final WindowState mAttachedWindow;
726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final ArrayList<WindowState> mChildWindows = new ArrayList<WindowState>();
736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final int mBaseLayer;
746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final int mSubLayer;
756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final boolean mLayoutAttached;
766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final boolean mIsImWindow;
776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final boolean mIsWallpaper;
786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final boolean mIsFloatingLayer;
795fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn    boolean mEnforceSizeCompat;
806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mViewVisibility;
816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mPolicyVisibility = true;
826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mPolicyVisibilityAfterAnim = true;
836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mAppFreezing;
846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    Surface mSurface;
856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mReportDestroySurface;
866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mSurfacePendingDestroy;
876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mAttachedHidden;    // is our parent window hidden?
886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mLastHidden;        // was this window last hidden?
896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mWallpaperVisible;  // for wallpaper, what was last vis report?
90ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn
91ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    /**
92ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * The window size that was requested by the application.  These are in
93ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * the application's coordinate space (without compatibility scale applied).
94ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     */
956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mRequestedWidth;
966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mRequestedHeight;
97ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn
986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mLayer;
996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mAnimLayer;
1006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mLastLayer;
1016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mHaveFrame;
1026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mObscured;
1036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mTurnOnScreen;
1046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mLayoutSeq = -1;
1066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    Configuration mConfiguration = null;
1086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
109ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    /**
110ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * Actual frame shown on-screen (may be modified by animation).  These
111ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * are in the screen's coordinate space (WITH the compatibility scale
112ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * applied).
113ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     */
114d040edbae968d826aa2c82d382345811a45c646bDianne Hackborn    final RectF mShownFrame = new RectF();
1156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
1176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Set when we have changed the size of the surface, to know that
1186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * we must tell them application to resize (and thus redraw itself).
1196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mSurfaceResized;
1216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
123ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * Insets that determine the actually visible area.  These are in the application's
124ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * coordinate space (without compatibility scale applied).
1256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mVisibleInsets = new Rect();
1276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mLastVisibleInsets = new Rect();
1286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mVisibleInsetsChanged;
1296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
131ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * Insets that are covered by system windows.  These are in the application's
132ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn     * coordinate space (without compatibility scale applied).
1336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mContentInsets = new Rect();
1356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mLastContentInsets = new Rect();
1366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mContentInsetsChanged;
1376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
1396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Set to true if we are waiting for this window to receive its
1406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * given internal insets before laying out other windows based on it.
1416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mGivenInsetsPending;
1436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
1456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * These are the content insets that were given during layout for
1466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * this window, to be applied to windows behind it.
1476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mGivenContentInsets = new Rect();
1496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
1516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * These are the visible insets that were given during layout for
1526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * this window, to be applied to windows behind it.
1536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mGivenVisibleInsets = new Rect();
1556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
1576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * This is the given touchable area relative to the window frame, or null if none.
1586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Region mGivenTouchableRegion = new Region();
1606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
1626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Flag indicating whether the touchable region should be adjusted by
1636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * the visible insets; if false the area outside the visible insets is
1646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * NOT touchable, so we must use those to adjust the frame during hit
1656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * tests.
1666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
1676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mTouchableInsets = ViewTreeObserver.InternalInsetsInfo.TOUCHABLE_INSETS_FRAME;
1686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Current transformation being applied.
1706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mHaveMatrix;
171e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn    float mGlobalScale=1;
172ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    float mInvGlobalScale=1;
1736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mDsDx=1, mDtDx=0, mDsDy=0, mDtDy=1;
1746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mLastDsDx=1, mLastDtDx=0, mLastDsDy=0, mLastDtDy=1;
1756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mHScale=1, mVScale=1;
1766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mLastHScale=1, mLastVScale=1;
1776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Matrix mTmpMatrix = new Matrix();
1786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
179ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    // "Real" frame that the application sees, in display coordinate space.
1806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mFrame = new Rect();
1816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mLastFrame = new Rect();
182ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    // Frame that is scaled to the application's coordinate space when in
183ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    // screen size compatibility mode.
184ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    final Rect mCompatFrame = new Rect();
1856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mContainingFrame = new Rect();
1876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mDisplayFrame = new Rect();
1886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mContentFrame = new Rect();
1896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mParentFrame = new Rect();
1906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Rect mVisibleFrame = new Rect();
1916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mContentChanged;
1936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mShownAlpha = 1;
1956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mAlpha = 1;
1966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mLastAlpha = 1;
1976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Set to true if, when the window gets displayed, it should perform
1996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // an enter animation.
2006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mEnterAnimationPending;
2016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Currently running animation.
2036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mAnimating;
2046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mLocalAnimating;
2056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    Animation mAnimation;
2066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mAnimationIsEntrance;
2076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mHasTransformation;
2086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mHasLocalTransformation;
2096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    final Transformation mTransformation = new Transformation();
2106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // If a window showing a wallpaper: the requested offset for the
2126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // wallpaper; if a wallpaper window: the currently applied offset.
2136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mWallpaperX = -1;
2146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mWallpaperY = -1;
2156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // If a window showing a wallpaper: what fraction of the offset
2176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // range corresponds to a full virtual screen.
2186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mWallpaperXStep = -1;
2196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mWallpaperYStep = -1;
2206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Wallpaper windows: pixels offset based on above variables.
2226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mXOffset;
2236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mYOffset;
2246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This is set after IWindowSession.relayout() has been called at
2266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // least once for the window.  It allows us to detect the situation
2276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // where we don't yet have a surface, but should have one soon, so
2286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // we can give the window focus before waiting for the relayout.
2296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mRelayoutCalled;
2306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This is set after the Surface has been created but before the
2326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // window has been drawn.  During this time the surface is hidden.
2336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mDrawPending;
2346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This is set after the window has finished drawing for the first
2366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // time but before its surface is shown.  The surface will be
2376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // displayed when the next layout is run.
2386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mCommitDrawPending;
2396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This is set during the time after the window's drawing has been
2416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // committed, and before its surface is actually shown.  It is used
2426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // to delay showing the surface until all windows in a token are ready
2436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // to be shown.
2446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mReadyToShow;
2456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Set when the window has been shown in the screen the first time.
2476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mHasDrawn;
2486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Currently running an exit animation?
2506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mExiting;
2516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Currently on the mDestroySurface list?
2536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mDestroying;
2546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Completely remove from window manager after exit animation?
2566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mRemoveOnExit;
2576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Set when the orientation is changing and this window has not yet
2596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // been updated for the new orientation.
2606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mOrientationChanging;
2616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Is this window now (or just being) removed?
2636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mRemoved;
2646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Temp for keeping track of windows that have been removed when
2666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // rebuilding window list.
2676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mRebuilding;
2686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // For debugging, this is the last information given to the surface flinger.
2706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mSurfaceShown;
271d040edbae968d826aa2c82d382345811a45c646bDianne Hackborn    float mSurfaceX, mSurfaceY, mSurfaceW, mSurfaceH;
2726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    int mSurfaceLayer;
2736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    float mSurfaceAlpha;
2746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Input channel and input window handle used by the input dispatcher.
2769302c8796fc4dcda08d4bd1e11733848fd4fafafJeff Brown    final InputWindowHandle mInputWindowHandle;
2776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    InputChannel mInputChannel;
2786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // Used to improve performance of toString()
2806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    String mStringNameCache;
2816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    CharSequence mLastTitle;
2826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean mWasPaused;
2836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
2846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    WindowState(WindowManagerService service, Session s, IWindow c, WindowToken token,
2856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn           WindowState attachedWindow, WindowManager.LayoutParams a,
2866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn           int viewVisibility) {
2876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mService = service;
2886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mSession = s;
2896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mClient = c;
2906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mToken = token;
2916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAttrs.copyFrom(a);
2926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mViewVisibility = viewVisibility;
2936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        DeathRecipient deathRecipient = new DeathRecipient();
2946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAlpha = a.alpha;
295e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        mEnforceSizeCompat = (mAttrs.flags & FLAG_COMPATIBLE_WINDOW) != 0;
2966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.localLOGV) Slog.v(
2976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            WindowManagerService.TAG, "Window " + this + " client=" + c.asBinder()
2986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            + " token=" + token + " (" + mAttrs.token + ")");
2996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        try {
3006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            c.asBinder().linkToDeath(deathRecipient, 0);
3016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } catch (RemoteException e) {
3026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDeathRecipient = null;
3036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAttachedWindow = null;
3046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLayoutAttached = false;
3056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsImWindow = false;
3066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsWallpaper = false;
3076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsFloatingLayer = false;
3086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mBaseLayer = 0;
3096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSubLayer = 0;
3109302c8796fc4dcda08d4bd1e11733848fd4fafafJeff Brown            mInputWindowHandle = null;
3116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return;
3126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
3136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mDeathRecipient = deathRecipient;
3146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if ((mAttrs.type >= FIRST_SUB_WINDOW &&
3166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAttrs.type <= LAST_SUB_WINDOW)) {
3176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // The multiplier here is to reserve space for multiple
3186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // windows in the same type layer.
3196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mBaseLayer = mService.mPolicy.windowTypeToLayerLw(
3206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    attachedWindow.mAttrs.type) * WindowManagerService.TYPE_LAYER_MULTIPLIER
3216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + WindowManagerService.TYPE_LAYER_OFFSET;
3226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSubLayer = mService.mPolicy.subWindowTypeToLayerLw(a.type);
3236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAttachedWindow = attachedWindow;
3246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (WindowManagerService.DEBUG_ADD_REMOVE) Slog.v(WindowManagerService.TAG, "Adding " + this + " to " + mAttachedWindow);
3256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAttachedWindow.mChildWindows.add(this);
3266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLayoutAttached = mAttrs.type !=
3276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    WindowManager.LayoutParams.TYPE_APPLICATION_ATTACHED_DIALOG;
3286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsImWindow = attachedWindow.mAttrs.type == TYPE_INPUT_METHOD
3296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    || attachedWindow.mAttrs.type == TYPE_INPUT_METHOD_DIALOG;
3306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsWallpaper = attachedWindow.mAttrs.type == TYPE_WALLPAPER;
3316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsFloatingLayer = mIsImWindow || mIsWallpaper;
3326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } else {
3336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // The multiplier here is to reserve space for multiple
3346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // windows in the same type layer.
3356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mBaseLayer = mService.mPolicy.windowTypeToLayerLw(a.type)
3366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    * WindowManagerService.TYPE_LAYER_MULTIPLIER
3376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + WindowManagerService.TYPE_LAYER_OFFSET;
3386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSubLayer = 0;
3396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAttachedWindow = null;
3406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLayoutAttached = false;
3416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsImWindow = mAttrs.type == TYPE_INPUT_METHOD
3426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    || mAttrs.type == TYPE_INPUT_METHOD_DIALOG;
3436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsWallpaper = mAttrs.type == TYPE_WALLPAPER;
3446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mIsFloatingLayer = mIsImWindow || mIsWallpaper;
3456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
3466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        WindowState appWin = this;
3486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        while (appWin.mAttachedWindow != null) {
3496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            appWin = mAttachedWindow;
3506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
3516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        WindowToken appToken = appWin.mToken;
3526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        while (appToken.appWindowToken == null) {
3536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            WindowToken parent = mService.mTokenMap.get(appToken.token);
3546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (parent == null || appToken == parent) {
3556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                break;
3566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
3576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            appToken = parent;
3586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
3596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mRootToken = appToken;
3606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAppToken = appToken.appWindowToken;
3616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mSurface = null;
3636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mRequestedWidth = 0;
3646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mRequestedHeight = 0;
3656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mXOffset = 0;
3666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mYOffset = 0;
3676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mLayer = 0;
3686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimLayer = 0;
3696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mLastLayer = 0;
3706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mInputWindowHandle = new InputWindowHandle(
3716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAppToken != null ? mAppToken.mInputApplicationHandle : null, this);
3726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
3736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    void attach() {
3756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.localLOGV) Slog.v(
3766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            WindowManagerService.TAG, "Attaching " + this + " token=" + mToken
3776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            + ", list=" + mToken.windows);
3786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mSession.windowAddedLocked();
3796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
3806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public void computeFrameLw(Rect pf, Rect df, Rect cf, Rect vf) {
3826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mHaveFrame = true;
3836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect container = mContainingFrame;
3856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        container.set(pf);
3866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect display = mDisplayFrame;
3886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        display.set(df);
3896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final int pw = container.right - container.left;
3916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final int ph = container.bottom - container.top;
3926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
3936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        int w,h;
394ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        if ((mAttrs.flags & WindowManager.LayoutParams.FLAG_SCALED) != 0) {
395ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            if (mAttrs.width < 0) {
396ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                w = pw;
397ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else if (mEnforceSizeCompat) {
398ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                w = (int)(mAttrs.width * mGlobalScale + .5f);
399ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else {
400ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                w = mAttrs.width;
401ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            }
402ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            if (mAttrs.height < 0) {
403ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                h = ph;
404ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else if (mEnforceSizeCompat) {
405ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                h = (int)(mAttrs.height * mGlobalScale + .5f);
406ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else {
407ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                h = mAttrs.height;
408ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            }
4096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } else {
410ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            if (mAttrs.width == WindowManager.LayoutParams.MATCH_PARENT) {
411ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                w = pw;
412ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else if (mEnforceSizeCompat) {
413ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                w = (int)(mRequestedWidth * mGlobalScale + .5f);
414ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else {
415ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                w = mRequestedWidth;
416ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            }
417ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            if (mAttrs.height == WindowManager.LayoutParams.MATCH_PARENT) {
418ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                h = ph;
419ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else if (mEnforceSizeCompat) {
420ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                h = (int)(mRequestedHeight * mGlobalScale + .5f);
421ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            } else {
422ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                h = mRequestedHeight;
423ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            }
4246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
4256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mParentFrame.equals(pf)) {
4276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            //Slog.i(TAG, "Window " + this + " content frame from " + mParentFrame
4286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            //        + " to " + pf);
4296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mParentFrame.set(pf);
4306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mContentChanged = true;
4316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
4326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect content = mContentFrame;
4346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        content.set(cf);
4356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect visible = mVisibleFrame;
4376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        visible.set(vf);
4386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect frame = mFrame;
4406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final int fw = frame.width();
4416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final int fh = frame.height();
4426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        //System.out.println("In: w=" + w + " h=" + h + " container=" +
4446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        //                   container + " x=" + mAttrs.x + " y=" + mAttrs.y);
4456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
446ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        float x, y;
447ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        if (mEnforceSizeCompat) {
448ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            x = mAttrs.x * mGlobalScale;
449ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            y = mAttrs.y * mGlobalScale;
450ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        } else {
451ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            x = mAttrs.x;
452ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            y = mAttrs.y;
453ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        }
454ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn
4556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        Gravity.apply(mAttrs.gravity, w, h, container,
456ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                (int) (x + mAttrs.horizontalMargin * pw),
457ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                (int) (y + mAttrs.verticalMargin * ph), frame);
4586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        //System.out.println("Out: " + mFrame);
4606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        // Now make sure the window fits in the overall display.
4626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        Gravity.applyDisplay(mAttrs.gravity, df, frame);
4636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        // Make sure the content and visible frames are inside of the
4656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        // final window frame.
4666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (content.left < frame.left) content.left = frame.left;
4676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (content.top < frame.top) content.top = frame.top;
4686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (content.right > frame.right) content.right = frame.right;
4696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (content.bottom > frame.bottom) content.bottom = frame.bottom;
4706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (visible.left < frame.left) visible.left = frame.left;
4716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (visible.top < frame.top) visible.top = frame.top;
4726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (visible.right > frame.right) visible.right = frame.right;
4736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (visible.bottom > frame.bottom) visible.bottom = frame.bottom;
4746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect contentInsets = mContentInsets;
4766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        contentInsets.left = content.left-frame.left;
4776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        contentInsets.top = content.top-frame.top;
4786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        contentInsets.right = frame.right-content.right;
4796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        contentInsets.bottom = frame.bottom-content.bottom;
4806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
4816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final Rect visibleInsets = mVisibleInsets;
4826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        visibleInsets.left = visible.left-frame.left;
4836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        visibleInsets.top = visible.top-frame.top;
4846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        visibleInsets.right = frame.right-visible.right;
4856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        visibleInsets.bottom = frame.bottom-visible.bottom;
4866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
487ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        mCompatFrame.set(frame);
488e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        if (mEnforceSizeCompat) {
489ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            // If there is a size compatibility scale being applied to the
490ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            // window, we need to apply this to its insets so that they are
491ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            // reported to the app in its coordinate space.
492ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            contentInsets.scale(mInvGlobalScale);
493ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            visibleInsets.scale(mInvGlobalScale);
494ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn
495ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            // Also the scaled frame that we report to the app needs to be
496ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            // adjusted to be in its coordinate space.
497ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            mCompatFrame.scale(mInvGlobalScale);
498e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        }
499e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn
5006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mIsWallpaper && (fw != frame.width() || fh != frame.height())) {
501bc68a59c024bdb745dac8e2ec7408a9f30595f1aJeff Brown            mService.updateWallpaperOffsetLocked(this,
502bc68a59c024bdb745dac8e2ec7408a9f30595f1aJeff Brown                    mService.mAppDisplayWidth, mService.mAppDisplayHeight, false);
5036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
5046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.localLOGV) {
5066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            //if ("com.google.android.youtube".equals(mAttrs.packageName)
5076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            //        && mAttrs.type == WindowManager.LayoutParams.TYPE_APPLICATION_PANEL) {
5086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.v(WindowManagerService.TAG, "Resolving (mRequestedWidth="
5096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + mRequestedWidth + ", mRequestedheight="
5106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + mRequestedHeight + ") to" + " (pw=" + pw + ", ph=" + ph
5116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + "): frame=" + mFrame.toShortString()
5126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + " ci=" + contentInsets.toShortString()
5136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + " vi=" + visibleInsets.toShortString());
5146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            //}
5156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
5166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public Rect getFrameLw() {
5196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mFrame;
5206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
522d040edbae968d826aa2c82d382345811a45c646bDianne Hackborn    public RectF getShownFrameLw() {
5236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mShownFrame;
5246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public Rect getDisplayFrameLw() {
5276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mDisplayFrame;
5286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public Rect getContentFrameLw() {
5316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mContentFrame;
5326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public Rect getVisibleFrameLw() {
5356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mVisibleFrame;
5366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean getGivenInsetsPendingLw() {
5396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mGivenInsetsPending;
5406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public Rect getGivenContentInsetsLw() {
5436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mGivenContentInsets;
5446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public Rect getGivenVisibleInsetsLw() {
5476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mGivenVisibleInsets;
5486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public WindowManager.LayoutParams getAttrs() {
5516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mAttrs;
5526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public int getSurfaceLayer() {
5556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mLayer;
5566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public IApplicationToken getAppToken() {
5596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mAppToken != null ? mAppToken.appToken : null;
5606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public long getInputDispatchingTimeoutNanos() {
5636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mAppToken != null
5646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                ? mAppToken.inputDispatchingTimeoutNanos
5656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                : WindowManagerService.DEFAULT_INPUT_DISPATCHING_TIMEOUT_NANOS;
5666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean hasAppShownWindows() {
5696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mAppToken != null ? mAppToken.firstWindowDrawn : false;
5706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public void setAnimation(Animation anim) {
5736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.localLOGV) Slog.v(
5746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            WindowManagerService.TAG, "Setting animation in " + this + ": " + anim);
5756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimating = false;
5766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mLocalAnimating = false;
5776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimation = anim;
5786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimation.restrictDuration(WindowManagerService.MAX_ANIMATION_DURATION);
5796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimation.scaleCurrentDuration(mService.mWindowAnimationScale);
5806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public void clearAnimation() {
5836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAnimation != null) {
5846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimating = true;
5856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLocalAnimating = false;
5866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimation.cancel();
5876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimation = null;
5886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
5896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
5906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
5916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    Surface createSurfaceLocked() {
5926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mSurface == null) {
5936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mReportDestroySurface = false;
5946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfacePendingDestroy = false;
5956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDrawPending = true;
5966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mCommitDrawPending = false;
5976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mReadyToShow = false;
5986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mAppToken != null) {
5996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAppToken.allDrawn = false;
6006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
6016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
6026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            int flags = 0;
6036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
6046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if ((mAttrs.flags&WindowManager.LayoutParams.FLAG_SECURE) != 0) {
6056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                flags |= Surface.SECURE;
6066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
6075fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (DEBUG_VISIBILITY) Slog.v(
6086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowManagerService.TAG, "Creating surface in session "
6096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + mSession.mSurfaceSession + " window " + this
610ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                + " w=" + mCompatFrame.width()
611ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                + " h=" + mCompatFrame.height() + " format="
6126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + mAttrs.format + " flags=" + flags);
6136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
614ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            int w = mCompatFrame.width();
615ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            int h = mCompatFrame.height();
6166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if ((mAttrs.flags & LayoutParams.FLAG_SCALED) != 0) {
6176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // for a scaled surface, we always want the requested
6186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // size.
6196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                w = mRequestedWidth;
6206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                h = mRequestedHeight;
6216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
6226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
6236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // Something is wrong and SurfaceFlinger will not like this,
6246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // try to revert to sane values
6256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (w <= 0) w = 1;
6266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (h <= 0) h = 1;
6276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
6286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceShown = false;
6296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceLayer = 0;
6306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceAlpha = 1;
6316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceX = 0;
6326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceY = 0;
6336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceW = w;
6346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceH = h;
6356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            try {
6366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                final boolean isHwAccelerated = (mAttrs.flags &
6376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED) != 0;
6386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                final int format = isHwAccelerated ? PixelFormat.TRANSLUCENT : mAttrs.format;
6396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (isHwAccelerated && mAttrs.format == PixelFormat.OPAQUE) {
6406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    flags |= Surface.OPAQUE;
6416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
6426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mSurface = new Surface(
6436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mSession.mSurfaceSession, mSession.mPid,
6446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mAttrs.getTitle().toString(),
6456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        0, w, h, format, flags);
6465fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                if (SHOW_TRANSACTIONS || SHOW_SURFACE_ALLOC) Slog.i(WindowManagerService.TAG,
6475fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                        "  CREATE SURFACE "
6486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + mSurface + " IN SESSION "
6496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + mSession.mSurfaceSession
6506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + ": pid=" + mSession.mPid + " format="
6516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + mAttrs.format + " flags=0x"
6526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + Integer.toHexString(flags)
6536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + " / " + this);
6546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } catch (Surface.OutOfResourcesException e) {
6556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.w(WindowManagerService.TAG, "OutOfResourcesException creating surface");
656648251710162cdaf7371012a1cbb79b9bc5bc0e4Dianne Hackborn                mService.reclaimSomeSurfaceMemoryLocked(this, "create", true);
6576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                return null;
6586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } catch (Exception e) {
6596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.e(WindowManagerService.TAG, "Exception creating surface", e);
6606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                return null;
6616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
6626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
6636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (WindowManagerService.localLOGV) Slog.v(
6646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowManagerService.TAG, "Got surface: " + mSurface
6656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + ", set left=" + mFrame.left + " top=" + mFrame.top
6666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + ", animLayer=" + mAnimLayer);
6675fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (SHOW_TRANSACTIONS) {
6686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.i(WindowManagerService.TAG, ">>> OPEN TRANSACTION createSurfaceLocked");
669ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                WindowManagerService.logSurface(this, "CREATE pos=(" + mFrame.left
670ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                        + "," + mFrame.top + ") (" +
671ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                        mCompatFrame.width() + "x" + mCompatFrame.height() + "), layer=" +
6726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mAnimLayer + " HIDE", null);
6736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
6746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            Surface.openTransaction();
6756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            try {
6766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                try {
6776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurfaceX = mFrame.left + mXOffset;
6786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurfaceY = mFrame.top + mYOffset;
6796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurface.setPosition(mSurfaceX, mSurfaceY);
6806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurfaceLayer = mAnimLayer;
6816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurface.setLayer(mAnimLayer);
6826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurfaceShown = false;
6836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mSurface.hide();
6846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if ((mAttrs.flags&WindowManager.LayoutParams.FLAG_DITHER) != 0) {
6855fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                        if (SHOW_TRANSACTIONS) WindowManagerService.logSurface(this, "DITHER", null);
6866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mSurface.setFlags(Surface.SURFACE_DITHER,
6876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                                Surface.SURFACE_DITHER);
6886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    }
6896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                } catch (RuntimeException e) {
6906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    Slog.w(WindowManagerService.TAG, "Error creating surface in " + w, e);
691648251710162cdaf7371012a1cbb79b9bc5bc0e4Dianne Hackborn                    mService.reclaimSomeSurfaceMemoryLocked(this, "create-init", true);
6926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
6936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mLastHidden = true;
6946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } finally {
6956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Surface.closeTransaction();
6965fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                if (SHOW_TRANSACTIONS) Slog.i(WindowManagerService.TAG, "<<< CLOSE TRANSACTION createSurfaceLocked");
6976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
6986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (WindowManagerService.localLOGV) Slog.v(
6996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    WindowManagerService.TAG, "Created surface " + this);
7006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
7016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface;
7026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
7036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    void destroySurfaceLocked() {
7056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAppToken != null && this == mAppToken.startingWindow) {
7066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAppToken.startingDisplayed = false;
7076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
7086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mSurface != null) {
7106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDrawPending = false;
7116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mCommitDrawPending = false;
7126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mReadyToShow = false;
7136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            int i = mChildWindows.size();
7156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            while (i > 0) {
7166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                i--;
7176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowState c = mChildWindows.get(i);
7186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                c.mAttachedHidden = true;
7196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
7206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mReportDestroySurface) {
7226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mReportDestroySurface = false;
7236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mSurfacePendingDestroy = true;
7246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                try {
7256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mClient.dispatchGetNewSurface();
7266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    // We'll really destroy on the next time around.
7276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    return;
7286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                } catch (RemoteException e) {
7296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
7306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
7316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            try {
7335fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                if (DEBUG_VISIBILITY) {
7346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    RuntimeException e = null;
7356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (!WindowManagerService.HIDE_STACK_CRAWLS) {
7366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        e = new RuntimeException();
7376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        e.fillInStackTrace();
7386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    }
7396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    Slog.w(WindowManagerService.TAG, "Window " + this + " destroying surface "
7406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                            + mSurface + ", session " + mSession, e);
7416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
7425fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                if (SHOW_TRANSACTIONS || SHOW_SURFACE_ALLOC) {
7436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    RuntimeException e = null;
7446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (!WindowManagerService.HIDE_STACK_CRAWLS) {
7456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        e = new RuntimeException();
7466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        e.fillInStackTrace();
7476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    }
7485fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn                    WindowManagerService.logSurface(this, "DESTROY", e);
7496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
7506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mSurface.destroy();
7516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } catch (RuntimeException e) {
7526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.w(WindowManagerService.TAG, "Exception thrown when destroying Window " + this
7536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " surface " + mSurface + " session " + mSession
7546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + ": " + e.toString());
7556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
7566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceShown = false;
7586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurface = null;
7596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
7606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
7616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean finishDrawingLocked() {
7636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mDrawPending) {
7645fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (SHOW_TRANSACTIONS || WindowManagerService.DEBUG_ORIENTATION) Slog.v(
7656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowManagerService.TAG, "finishDrawingLocked: " + mSurface);
7666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mCommitDrawPending = true;
7676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDrawPending = false;
7686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return true;
7696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
7706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return false;
7716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
7726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This must be called while inside a transaction.
7746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean commitFinishDrawingLocked(long currentTime) {
7756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        //Slog.i(TAG, "commitFinishDrawingLocked: " + mSurface);
7766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mCommitDrawPending) {
7776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return false;
7786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
7796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mCommitDrawPending = false;
7806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mReadyToShow = true;
7816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final boolean starting = mAttrs.type == TYPE_APPLICATION_STARTING;
7826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
7836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (atoken == null || atoken.allDrawn || starting) {
7846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            performShowLocked();
7856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
7866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return true;
7876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
7886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
7896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This must be called while inside a transaction.
7906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean performShowLocked() {
7915fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn        if (DEBUG_VISIBILITY) {
7926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            RuntimeException e = null;
7936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (!WindowManagerService.HIDE_STACK_CRAWLS) {
7946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                e = new RuntimeException();
7956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                e.fillInStackTrace();
7966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
7976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            Slog.v(WindowManagerService.TAG, "performShow on " + this
7986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + ": readyToShow=" + mReadyToShow + " readyForDisplay=" + isReadyForDisplay()
7996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " starting=" + (mAttrs.type == TYPE_APPLICATION_STARTING), e);
8006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
8016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mReadyToShow && isReadyForDisplay()) {
8025fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (SHOW_TRANSACTIONS || WindowManagerService.DEBUG_ORIENTATION) WindowManagerService.logSurface(this,
8036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    "SHOW (performShowLocked)", null);
8045fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (DEBUG_VISIBILITY) Slog.v(WindowManagerService.TAG, "Showing " + this
8056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " during animation: policyVis=" + mPolicyVisibility
8066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " attHidden=" + mAttachedHidden
8076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " tok.hiddenRequested="
8086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + (mAppToken != null ? mAppToken.hiddenRequested : false)
8096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " tok.hidden="
8106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + (mAppToken != null ? mAppToken.hidden : false)
8116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " animating=" + mAnimating
8126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " tok animating="
8136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + (mAppToken != null ? mAppToken.animating : false));
8146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (!mService.showSurfaceRobustlyLocked(this)) {
8156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                return false;
8166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
8176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLastAlpha = -1;
8186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mHasDrawn = true;
8196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLastHidden = false;
8206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mReadyToShow = false;
8216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.enableScreenIfNeededLocked();
8226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
8236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.applyEnterAnimationLocked(this);
8246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
8256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            int i = mChildWindows.size();
8266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            while (i > 0) {
8276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                i--;
8286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowState c = mChildWindows.get(i);
8296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (c.mAttachedHidden) {
8306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    c.mAttachedHidden = false;
8316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (c.mSurface != null) {
8326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        c.performShowLocked();
8336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        // It hadn't been shown, which means layout not
8346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        // performed on it, so now we want to make sure to
8356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        // do a layout.  If called from within the transaction
8366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        // loop, this will cause it to restart with a new
8376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        // layout.
8386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mService.mLayoutNeeded = true;
8396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    }
8406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
8416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
8426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
8436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mAttrs.type != TYPE_APPLICATION_STARTING
8446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    && mAppToken != null) {
8456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAppToken.firstWindowDrawn = true;
8466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
8476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (mAppToken.startingData != null) {
8486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (WindowManagerService.DEBUG_STARTING_WINDOW || WindowManagerService.DEBUG_ANIM) Slog.v(WindowManagerService.TAG,
8496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                            "Finish starting " + mToken
8506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                            + ": first real window is shown, no animation");
8516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    // If this initial window is animating, stop it -- we
8526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    // will do an animation to reveal it from behind the
8536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    // starting window, so there is no need for it to also
8546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    // be doing its own stuff.
8556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (mAnimation != null) {
8566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mAnimation.cancel();
8576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mAnimation = null;
8586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        // Make sure we clean up the animation.
8596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mAnimating = true;
8606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    }
8616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mService.mFinishedStarting.add(mAppToken);
8626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mService.mH.sendEmptyMessage(H.FINISHED_STARTING);
8636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
8646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAppToken.updateReportedVisibilityLocked();
8656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
8666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
8676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return true;
8686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
8696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
8706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // This must be called while inside a transaction.  Returns true if
8716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    // there is more animation to run.
8726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean stepAnimationLocked(long currentTime, int dw, int dh) {
8736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mService.mDisplayFrozen && mService.mPolicy.isScreenOn()) {
8746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // We will run animations as long as the display isn't frozen.
8756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
8766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (!mDrawPending && !mCommitDrawPending && mAnimation != null) {
8776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mHasTransformation = true;
8786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mHasLocalTransformation = true;
8796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (!mLocalAnimating) {
8806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (WindowManagerService.DEBUG_ANIM) Slog.v(
8816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        WindowManagerService.TAG, "Starting animation in " + this +
882ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                        " @ " + currentTime + ": ww=" + mFrame.width() +
883ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                        " wh=" + mFrame.height() +
8846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        " dw=" + dw + " dh=" + dh + " scale=" + mService.mWindowAnimationScale);
885ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                    mAnimation.initialize(mFrame.width(), mFrame.height(), dw, dh);
8866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mAnimation.setStartTime(currentTime);
8876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mLocalAnimating = true;
8886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mAnimating = true;
8896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
8906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mTransformation.clear();
8916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                final boolean more = mAnimation.getTransformation(
8926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    currentTime, mTransformation);
8936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (WindowManagerService.DEBUG_ANIM) Slog.v(
8946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    WindowManagerService.TAG, "Stepped animation in " + this +
8956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    ": more=" + more + ", xform=" + mTransformation);
8966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (more) {
8976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    // we're not done!
8986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    return true;
8996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
9006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (WindowManagerService.DEBUG_ANIM) Slog.v(
9016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    WindowManagerService.TAG, "Finished animation in " + this +
9026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    " @ " + currentTime);
9036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
9046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (mAnimation != null) {
9056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mAnimation.cancel();
9066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mAnimation = null;
9076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
9086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                //WindowManagerService.this.dump();
9096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
9106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mHasLocalTransformation = false;
9116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if ((!mLocalAnimating || mAnimationIsEntrance) && mAppToken != null
9126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    && mAppToken.animation != null) {
9136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // When our app token is animating, we kind-of pretend like
9146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // we are as well.  Note the mLocalAnimating mAnimationIsEntrance
9156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // part of this check means that we will only do this if
9166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // our window is not currently exiting, or it is not
9176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // locally animating itself.  The idea being that one that
9186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // is exiting and doing a local animation should be removed
9196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // once that animation is done.
9206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAnimating = true;
9216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mHasTransformation = true;
9226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mTransformation.clear();
9236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                return false;
9246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } else if (mHasTransformation) {
9256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // Little trick to get through the path below to act like
9266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // we have finished an animation.
9276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAnimating = true;
9286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } else if (isAnimating()) {
9296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mAnimating = true;
9306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
9316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } else if (mAnimation != null) {
9326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // If the display is frozen, and there is a pending animation,
9336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // clear it and make sure we run the cleanup code.
9346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimating = true;
9356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLocalAnimating = true;
9366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimation.cancel();
9376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimation = null;
9386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
9406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mAnimating && !mLocalAnimating) {
9416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return false;
9426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
9446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.DEBUG_ANIM) Slog.v(
9456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            WindowManagerService.TAG, "Animation done in " + this + ": exiting=" + mExiting
9466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            + ", reportedVisible="
9476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            + (mAppToken != null ? mAppToken.reportedVisible : false));
9486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
9496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimating = false;
9506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mLocalAnimating = false;
9516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAnimation != null) {
9526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimation.cancel();
9536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimation = null;
9546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mAnimLayer = mLayer;
9566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mIsImWindow) {
9576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimLayer += mService.mInputMethodAnimLayerAdjustment;
9586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } else if (mIsWallpaper) {
9596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAnimLayer += mService.mWallpaperAnimLayerAdjustment;
9606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.DEBUG_LAYERS) Slog.v(WindowManagerService.TAG, "Stepping win " + this
9626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + " anim layer: " + mAnimLayer);
9636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mHasTransformation = false;
9646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mHasLocalTransformation = false;
9656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mPolicyVisibility != mPolicyVisibilityAfterAnim) {
9665fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (DEBUG_VISIBILITY) {
9676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.v(WindowManagerService.TAG, "Policy visibility changing after anim in " + this + ": "
9686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        + mPolicyVisibilityAfterAnim);
9696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
9706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mPolicyVisibility = mPolicyVisibilityAfterAnim;
971f809870f118663055dc0f8b626204e7bb1133fb5Dianne Hackborn            mService.mLayoutNeeded = true;
9726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (!mPolicyVisibility) {
9736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (mService.mCurrentFocus == this) {
9746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mService.mFocusMayChange = true;
9756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
9766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // Window is no longer visible -- make sure if we were waiting
9776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // for it to be displayed before enabling the display, that
9786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // we allow the display to be enabled now.
9796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mService.enableScreenIfNeededLocked();
9806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
9816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mTransformation.clear();
9836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mHasDrawn
9846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mAttrs.type == WindowManager.LayoutParams.TYPE_APPLICATION_STARTING
9856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mAppToken != null
9866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mAppToken.firstWindowDrawn
9876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mAppToken.startingData != null) {
9886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (WindowManagerService.DEBUG_STARTING_WINDOW) Slog.v(WindowManagerService.TAG, "Finish starting "
9896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + mToken + ": first real window done animating");
9906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.mFinishedStarting.add(mAppToken);
9916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.mH.sendEmptyMessage(H.FINISHED_STARTING);
9926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
9946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        finishExit();
9956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
9966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAppToken != null) {
9976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAppToken.updateReportedVisibilityLocked();
9986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
9996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return false;
10016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
10026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    void finishExit() {
10046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.DEBUG_ANIM) Slog.v(
10056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowManagerService.TAG, "finishExit in " + this
10066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + ": exiting=" + mExiting
10076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + " remove=" + mRemoveOnExit
10086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + " windowAnimating=" + isWindowAnimating());
10096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final int N = mChildWindows.size();
10116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        for (int i=0; i<N; i++) {
10126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mChildWindows.get(i).finishExit();
10136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
10146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mExiting) {
10166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return;
10176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
10186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (isWindowAnimating()) {
10206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return;
10216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
10226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (WindowManagerService.localLOGV) Slog.v(
10246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowManagerService.TAG, "Exit animation finished in " + this
10256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                + ": remove=" + mRemoveOnExit);
10266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mSurface != null) {
10276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.mDestroySurface.add(this);
10286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDestroying = true;
10295fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (SHOW_TRANSACTIONS) WindowManagerService.logSurface(this, "HIDE (finishExit)", null);
10306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mSurfaceShown = false;
10316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            try {
10326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mSurface.hide();
10336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } catch (RuntimeException e) {
10346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                Slog.w(WindowManagerService.TAG, "Error hiding surface in " + this, e);
10356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
10366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLastHidden = true;
10376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
10386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mExiting = false;
10396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mRemoveOnExit) {
10406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.mPendingRemove.add(this);
10416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mRemoveOnExit = false;
10426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
10436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
10446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isIdentityMatrix(float dsdx, float dtdx, float dsdy, float dtdy) {
10466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (dsdx < .99999f || dsdx > 1.00001f) return false;
10476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (dtdy < .99999f || dtdy > 1.00001f) return false;
10486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (dtdx < -.000001f || dtdx > .000001f) return false;
10496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (dsdy < -.000001f || dsdy > .000001f) return false;
10506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return true;
10516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
10526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1053e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn    void prelayout() {
1054e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        if (mEnforceSizeCompat) {
1055e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn            mGlobalScale = mService.mCompatibleScreenScale;
1056ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            mInvGlobalScale = 1/mGlobalScale;
1057e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        } else {
1058ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            mGlobalScale = mInvGlobalScale = 1;
1059e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        }
1060e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn    }
1061e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn
10626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    void computeShownFrameLocked() {
10636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final boolean selfTransformation = mHasLocalTransformation;
10646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        Transformation attachedTransformation =
10656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                (mAttachedWindow != null && mAttachedWindow.mHasLocalTransformation)
10666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                ? mAttachedWindow.mTransformation : null;
10676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        Transformation appTransformation =
10686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                (mAppToken != null && mAppToken.hasTransformation)
10696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                ? mAppToken.transformation : null;
10706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        // Wallpapers are animated based on the "real" window they
10726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        // are currently targeting.
10736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAttrs.type == TYPE_WALLPAPER && mService.mLowerWallpaperTarget == null
10746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mService.mWallpaperTarget != null) {
10756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mService.mWallpaperTarget.mHasLocalTransformation &&
10766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mService.mWallpaperTarget.mAnimation != null &&
10776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    !mService.mWallpaperTarget.mAnimation.getDetachWallpaper()) {
10786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                attachedTransformation = mService.mWallpaperTarget.mTransformation;
10796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (WindowManagerService.DEBUG_WALLPAPER && attachedTransformation != null) {
10806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    Slog.v(WindowManagerService.TAG, "WP target attached xform: " + attachedTransformation);
10816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
10826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
10836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mService.mWallpaperTarget.mAppToken != null &&
10846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mService.mWallpaperTarget.mAppToken.hasTransformation &&
10856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mService.mWallpaperTarget.mAppToken.animation != null &&
10866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    !mService.mWallpaperTarget.mAppToken.animation.getDetachWallpaper()) {
10876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                appTransformation = mService.mWallpaperTarget.mAppToken.transformation;
10886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (WindowManagerService.DEBUG_WALLPAPER && appTransformation != null) {
10896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    Slog.v(WindowManagerService.TAG, "WP target app xform: " + appTransformation);
10906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
10916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
10926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
10936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
10946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final boolean screenAnimation = mService.mScreenRotationAnimation != null
10956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mService.mScreenRotationAnimation.isAnimating();
10966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (selfTransformation || attachedTransformation != null
10976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                || appTransformation != null || screenAnimation) {
10986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // cache often used attributes locally
10996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            final Rect frame = mFrame;
11006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            final float tmpFloats[] = mService.mTmpFloats;
11016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            final Matrix tmpMatrix = mTmpMatrix;
11026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // Compute the desired transformation.
11046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            tmpMatrix.setTranslate(0, 0);
1105e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn            tmpMatrix.postScale(mGlobalScale, mGlobalScale);
11066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (selfTransformation) {
11076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                tmpMatrix.postConcat(mTransformation.getMatrix());
11086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
11096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            tmpMatrix.postTranslate(frame.left + mXOffset, frame.top + mYOffset);
11106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (attachedTransformation != null) {
11116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                tmpMatrix.postConcat(attachedTransformation.getMatrix());
11126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
11136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (appTransformation != null) {
11146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                tmpMatrix.postConcat(appTransformation.getMatrix());
11156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
11166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (screenAnimation) {
11176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                tmpMatrix.postConcat(
11186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mService.mScreenRotationAnimation.getEnterTransformation().getMatrix());
11196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
11206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // "convert" it into SurfaceFlinger's format
11226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // (a 2x2 matrix + an offset)
11236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // Here we must not transform the position of the surface
11246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // since it is already included in the transformation.
11256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            //Slog.i(TAG, "Transform: " + matrix);
11266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mHaveMatrix = true;
11286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            tmpMatrix.getValues(tmpFloats);
11296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDsDx = tmpFloats[Matrix.MSCALE_X];
11306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDtDx = tmpFloats[Matrix.MSKEW_Y];
11316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDsDy = tmpFloats[Matrix.MSKEW_X];
11326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mDtDy = tmpFloats[Matrix.MSCALE_Y];
1133d040edbae968d826aa2c82d382345811a45c646bDianne Hackborn            float x = tmpFloats[Matrix.MTRANS_X];
1134d040edbae968d826aa2c82d382345811a45c646bDianne Hackborn            float y = tmpFloats[Matrix.MTRANS_Y];
11356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            int w = frame.width();
11366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            int h = frame.height();
11376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mShownFrame.set(x, y, x+w, y+h);
11386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // Now set the alpha...  but because our current hardware
11406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // can't do alpha transformation on a non-opaque surface,
11416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // turn it off if we are running an animation that is also
11426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // transforming since it is more important to have that
11436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // animation be smooth.
11446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mShownAlpha = mAlpha;
11456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (!mService.mLimitedAlphaCompositing
11466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    || (!PixelFormat.formatHasAlpha(mAttrs.format)
11476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    || (isIdentityMatrix(mDsDx, mDtDx, mDsDy, mDtDy)
11486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                            && x == frame.left && y == frame.top))) {
11496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                //Slog.i(TAG, "Applying alpha transform");
11506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (selfTransformation) {
11516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mShownAlpha *= mTransformation.getAlpha();
11526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
11536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (attachedTransformation != null) {
11546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mShownAlpha *= attachedTransformation.getAlpha();
11556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
11566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (appTransformation != null) {
11576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mShownAlpha *= appTransformation.getAlpha();
11586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
11596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                if (screenAnimation) {
11606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    mShownAlpha *=
11616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mService.mScreenRotationAnimation.getEnterTransformation().getAlpha();
11626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
11636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } else {
11646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                //Slog.i(TAG, "Not applying alpha transform");
11656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
11666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (WindowManagerService.localLOGV) Slog.v(
11686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                WindowManagerService.TAG, "Continuing animation in " + this +
11696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                ": " + mShownFrame +
11706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                ", alpha=" + mTransformation.getAlpha());
11716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return;
11726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
11736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mShownFrame.set(mFrame);
11756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mXOffset != 0 || mYOffset != 0) {
11766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mShownFrame.offset(mXOffset, mYOffset);
11776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
11786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mShownAlpha = mAlpha;
11796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mHaveMatrix = false;
1180e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        mDsDx = mGlobalScale;
11816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mDtDx = 0;
11826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mDsDy = 0;
1183e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        mDtDy = mGlobalScale;
11846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
11856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
11876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Is this window visible?  It is not visible if there is no
11886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * surface, or we are in the process of running an exit animation
11896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * that will remove the surface, or its app token has been hidden.
11906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
11916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean isVisibleLw() {
11926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
11936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && mPolicyVisibility && !mAttachedHidden
11946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (atoken == null || !atoken.hiddenRequested)
11956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mExiting && !mDestroying;
11966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
11976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
11986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
11996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Like {@link #isVisibleLw}, but also counts a window that is currently
12006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * "hidden" behind the keyguard as visible.  This allows us to apply
12016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * things like window flags that impact the keyguard.
12026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * XXX I am starting to think we need to have ANOTHER visibility flag
12036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * for this "hidden behind keyguard" state rather than overloading
12046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * mPolicyVisibility.  Ungh.
12056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean isVisibleOrBehindKeyguardLw() {
12076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
12086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && !mAttachedHidden
12096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (atoken == null ? mPolicyVisibility : !atoken.hiddenRequested)
12106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mDrawPending && !mCommitDrawPending
12116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mExiting && !mDestroying;
12126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
12156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Is this window visible, ignoring its app token?  It is not visible
12166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * if there is no surface, or we are in the process of running an exit animation
12176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * that will remove the surface.
12186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean isWinVisibleLw() {
12206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
12216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && mPolicyVisibility && !mAttachedHidden
12226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (atoken == null || !atoken.hiddenRequested || atoken.animating)
12236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mExiting && !mDestroying;
12246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
12276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * The same as isVisible(), but follows the current hidden state of
12286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * the associated app token, not the pending requested hidden state.
12296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isVisibleNow() {
12316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && mPolicyVisibility && !mAttachedHidden
12326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mRootToken.hidden && !mExiting && !mDestroying;
12336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
12366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Can this window possibly be a drag/drop target?  The test here is
12376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * a combination of the above "visible now" with the check that the
12386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Input Manager uses when discarding windows from input consideration.
12396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isPotentialDragTarget() {
1241cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown        return isVisibleNow() && !mRemoved
1242cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown                && mInputChannel != null && mInputWindowHandle != null;
12436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
12466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Same as isVisible(), but we also count it as visible between the
12476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * call to IWindowSession.add() and the first relayout().
12486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isVisibleOrAdding() {
12506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
12516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return ((mSurface != null && !mReportDestroySurface)
12526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        || (!mRelayoutCalled && mViewVisibility == View.VISIBLE))
12536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mPolicyVisibility && !mAttachedHidden
12546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (atoken == null || !atoken.hiddenRequested)
12556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mExiting && !mDestroying;
12566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
12596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Is this window currently on-screen?  It is on-screen either if it
12606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * is visible or it is currently running an animation before no longer
12616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * being visible.
12626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isOnScreen() {
12646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
12656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (atoken != null) {
12666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return mSurface != null && mPolicyVisibility && !mDestroying
12676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    && ((!mAttachedHidden && !atoken.hiddenRequested)
12686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                            || mAnimation != null || atoken.animation != null);
12696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } else {
12706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return mSurface != null && mPolicyVisibility && !mDestroying
12716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    && (!mAttachedHidden || mAnimation != null);
12726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
12736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
12766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Like isOnScreen(), but we don't return true if the window is part
12776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * of a transition that has not yet been started.
12786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
12796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isReadyForDisplay() {
12806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mRootToken.waitingToShow &&
12816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mService.mNextAppTransition != WindowManagerPolicy.TRANSIT_UNSET) {
12826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return false;
12836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
12846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
12856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final boolean animating = atoken != null
12866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                ? (atoken.animation != null) : false;
12876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && mPolicyVisibility && !mDestroying
12886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && ((!mAttachedHidden && mViewVisibility == View.VISIBLE
12896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                                && !mRootToken.hidden)
12906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        || mAnimation != null || animating);
12916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
12926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
12936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /** Is the window or its container currently animating? */
12946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isAnimating() {
12956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final WindowState attached = mAttachedWindow;
12966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
12976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mAnimation != null
12986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                || (attached != null && attached.mAnimation != null)
12996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                || (atoken != null &&
13006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        (atoken.animation != null
13016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                                || atoken.inPendingTransaction));
13026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /** Is this window currently animating? */
13056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isWindowAnimating() {
13066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mAnimation != null;
13076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
13106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Like isOnScreen, but returns false if the surface hasn't yet
13116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * been drawn.
13126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
13136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean isDisplayedLw() {
13146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
13156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && mPolicyVisibility && !mDestroying
13166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            && !mDrawPending && !mCommitDrawPending
13176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            && ((!mAttachedHidden &&
13186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    (atoken == null || !atoken.hiddenRequested))
13196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    || mAnimating);
13206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
13236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Returns true if the window has a surface that it has drawn a
13246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * complete UI in to.
13256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
13266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean isDrawnLw() {
13276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        final AppWindowToken atoken = mAppToken;
13286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mSurface != null && !mDestroying
13296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            && !mDrawPending && !mCommitDrawPending;
13306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
13336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Return true if the window is opaque and fully drawn.  This indicates
13346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * it may obscure windows behind it.
13356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
13366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isOpaqueDrawn() {
13376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return (mAttrs.format == PixelFormat.OPAQUE
13386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        || mAttrs.type == TYPE_WALLPAPER)
13396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mSurface != null && mAnimation == null
13406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (mAppToken == null || mAppToken.animation == null)
13416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && !mDrawPending && !mCommitDrawPending;
13426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /**
13456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * Return whether this window is wanting to have a translation
13466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * animation applied to it for an in-progress move.  (Only makes
13476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     * sense to call from performLayoutAndPlaceSurfacesLockedInner().)
13486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn     */
13496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean shouldAnimateMove() {
13506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mContentChanged && !mExiting && !mLastHidden && !mService.mDisplayFrozen
13516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (mFrame.top != mLastFrame.top
13526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        || mFrame.left != mLastFrame.left)
13536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (mAttachedWindow == null || !mAttachedWindow.shouldAnimateMove())
13546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && mService.mPolicy.isScreenOn();
13556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean isFullscreen(int screenWidth, int screenHeight) {
1358ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        return mFrame.left <= 0 && mFrame.top <= 0 &&
1359ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                mFrame.right >= screenWidth && mFrame.bottom >= screenHeight;
13606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    void removeLocked() {
13636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        disposeInputChannel();
13646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAttachedWindow != null) {
13666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (WindowManagerService.DEBUG_ADD_REMOVE) Slog.v(WindowManagerService.TAG, "Removing " + this + " from " + mAttachedWindow);
13676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mAttachedWindow.mChildWindows.remove(this);
13686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
13696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        destroySurfaceLocked();
13706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mSession.windowRemovedLocked();
13716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        try {
13726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mClient.asBinder().unlinkToDeath(mDeathRecipient, 0);
13736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } catch (RuntimeException e) {
13746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // Ignore if it has already been removed (usually because
13756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // we are doing this as part of processing a death note.)
13766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
13776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
1378cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown
1379cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown    void setInputChannel(InputChannel inputChannel) {
1380cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown        if (mInputChannel != null) {
1381cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown            throw new IllegalStateException("Window already has an input channel.");
1382cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown        }
1383cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown
1384cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown        mInputChannel = inputChannel;
1385cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown        mInputWindowHandle.inputChannel = inputChannel;
1386cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown    }
1387cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown
13886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    void disposeInputChannel() {
13896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mInputChannel != null) {
13906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.mInputManager.unregisterInputChannel(mInputChannel);
13916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mInputChannel.dispose();
13936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mInputChannel = null;
13946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
1395cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown
1396cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown        mInputWindowHandle.inputChannel = null;
13976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
13986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
13996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    private class DeathRecipient implements IBinder.DeathRecipient {
14006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        public void binderDied() {
14016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            try {
14026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                synchronized(mService.mWindowMap) {
14036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    WindowState win = mService.windowForClientLocked(mSession, mClient, false);
14046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    Slog.i(WindowManagerService.TAG, "WIN DEATH: " + win);
14056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    if (win != null) {
14066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                        mService.removeWindowLocked(mSession, win);
14076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    }
14086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                }
14096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } catch (IllegalArgumentException ex) {
14106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // This will happen if the window has already been
14116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // removed.
14126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
14136e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14146e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
14166e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    /** Returns true if this window desires key events. */
14176e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public final boolean canReceiveKeys() {
14186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return     isVisibleOrAdding()
14196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && (mViewVisibility == View.VISIBLE)
14206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                && ((mAttrs.flags & WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE) == 0);
14216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
14236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean hasDrawnLw() {
14246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mHasDrawn;
14256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
14276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean showLw(boolean doAnimation) {
14286e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return showLw(doAnimation, true);
14296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
14316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean showLw(boolean doAnimation, boolean requestAnim) {
14326e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mPolicyVisibility && mPolicyVisibilityAfterAnim) {
14336e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return false;
14346e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14355fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn        if (DEBUG_VISIBILITY) Slog.v(WindowManagerService.TAG, "Policy visibility true: " + this);
14366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (doAnimation) {
14375fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (DEBUG_VISIBILITY) Slog.v(WindowManagerService.TAG, "doAnimation: mPolicyVisibility="
14386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + mPolicyVisibility + " mAnimation=" + mAnimation);
14396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mService.mDisplayFrozen || !mService.mPolicy.isScreenOn()) {
14406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                doAnimation = false;
14416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            } else if (mPolicyVisibility && mAnimation == null) {
14426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // Check for the case where we are currently visible and
14436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // not animating; we do not want to do animation at such a
14446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                // point to become visible when we already are.
14456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                doAnimation = false;
14466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
14476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mPolicyVisibility = true;
14496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        mPolicyVisibilityAfterAnim = true;
14506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (doAnimation) {
14516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.applyAnimationLocked(this, WindowManagerPolicy.TRANSIT_ENTER, true);
14526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (requestAnim) {
14546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.requestAnimationLocked(0);
14556e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14566e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return true;
14576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
14596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public boolean hideLw(boolean doAnimation) {
14606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return hideLw(doAnimation, true);
14616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
14636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    boolean hideLw(boolean doAnimation, boolean requestAnim) {
14646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (doAnimation) {
14656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mService.mDisplayFrozen || !mService.mPolicy.isScreenOn()) {
14666e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                doAnimation = false;
14676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
14686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        boolean current = doAnimation ? mPolicyVisibilityAfterAnim
14706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                : mPolicyVisibility;
14716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!current) {
14726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            return false;
14736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (doAnimation) {
14756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.applyAnimationLocked(this, WindowManagerPolicy.TRANSIT_EXIT, false);
14766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mAnimation == null) {
14776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                doAnimation = false;
14786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
14796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (doAnimation) {
14816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mPolicyVisibilityAfterAnim = false;
14826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        } else {
14835fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn            if (DEBUG_VISIBILITY) Slog.v(WindowManagerService.TAG, "Policy visibility false: " + this);
14846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mPolicyVisibilityAfterAnim = false;
14856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mPolicyVisibility = false;
14866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // Window is no longer visible -- make sure if we were waiting
14876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // for it to be displayed before enabling the display, that
14886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            // we allow the display to be enabled now.
14896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.enableScreenIfNeededLocked();
14906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            if (mService.mCurrentFocus == this) {
14916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                mService.mFocusMayChange = true;
14926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
14936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (requestAnim) {
14956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mService.requestAnimationLocked(0);
14966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
14976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return true;
14986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
14996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1500ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn    private static void applyInsets(Region outRegion, Rect frame, Rect inset) {
1501ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        outRegion.set(
1502ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                frame.left + inset.left, frame.top + inset.top,
1503ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                frame.right - inset.right, frame.bottom - inset.bottom);
1504e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn    }
1505e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn
15066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public void getTouchableRegion(Region outRegion) {
1507ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        final Rect frame = mFrame;
15086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        switch (mTouchableInsets) {
15096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            default:
15106e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            case ViewTreeObserver.InternalInsetsInfo.TOUCHABLE_INSETS_FRAME:
15116e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                outRegion.set(frame);
15126e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                break;
1513e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn            case ViewTreeObserver.InternalInsetsInfo.TOUCHABLE_INSETS_CONTENT:
1514ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                applyInsets(outRegion, frame, mGivenContentInsets);
15156e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                break;
1516e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn            case ViewTreeObserver.InternalInsetsInfo.TOUCHABLE_INSETS_VISIBLE:
1517ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                applyInsets(outRegion, frame, mGivenVisibleInsets);
15186e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                break;
15196e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            case ViewTreeObserver.InternalInsetsInfo.TOUCHABLE_INSETS_REGION: {
15206e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                final Region givenTouchableRegion = mGivenTouchableRegion;
15216e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                outRegion.set(givenTouchableRegion);
15226e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                outRegion.translate(frame.left, frame.top);
15236e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                break;
15246e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            }
15256e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
15266e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
15276e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
1528a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn    void dump(PrintWriter pw, String prefix, boolean dumpAll) {
15296e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        pw.print(prefix); pw.print("mSession="); pw.print(mSession);
15306e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                pw.print(" mClient="); pw.println(mClient.asBinder());
15316e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        pw.print(prefix); pw.print("mAttrs="); pw.println(mAttrs);
1532a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        pw.print(prefix); pw.print("Requested w="); pw.print(mRequestedWidth);
1533a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                pw.print(" h="); pw.print(mRequestedHeight);
1534a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                pw.print(" mLayoutSeq="); pw.println(mLayoutSeq);
15356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAttachedWindow != null || mLayoutAttached) {
15366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mAttachedWindow="); pw.print(mAttachedWindow);
15376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mLayoutAttached="); pw.println(mLayoutAttached);
15386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
15396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mIsImWindow || mIsWallpaper || mIsFloatingLayer) {
15406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mIsImWindow="); pw.print(mIsImWindow);
15416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mIsWallpaper="); pw.print(mIsWallpaper);
15426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mIsFloatingLayer="); pw.print(mIsFloatingLayer);
15436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mWallpaperVisible="); pw.println(mWallpaperVisible);
15446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
1545a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        if (dumpAll) {
1546a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mBaseLayer="); pw.print(mBaseLayer);
1547a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mSubLayer="); pw.print(mSubLayer);
1548a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mAnimLayer="); pw.print(mLayer); pw.print("+");
1549a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print((mTargetAppToken != null ? mTargetAppToken.animLayerAdjustment
1550a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                          : (mAppToken != null ? mAppToken.animLayerAdjustment : 0)));
1551a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print("="); pw.print(mAnimLayer);
1552a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mLastLayer="); pw.println(mLastLayer);
1553a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        }
15546e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mSurface != null) {
1555a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            if (dumpAll) {
1556a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                pw.print(prefix); pw.print("mSurface="); pw.println(mSurface);
1557a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            }
15586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("Surface: shown="); pw.print(mSurfaceShown);
15596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" layer="); pw.print(mSurfaceLayer);
15606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" alpha="); pw.print(mSurfaceAlpha);
15616e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" rect=("); pw.print(mSurfaceX);
15626e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(","); pw.print(mSurfaceY);
15636e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(") "); pw.print(mSurfaceW);
15646e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" x "); pw.println(mSurfaceH);
15656e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
1566a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        if (dumpAll) {
1567a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mToken="); pw.println(mToken);
1568a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mRootToken="); pw.println(mRootToken);
1569a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            if (mAppToken != null) {
1570a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                pw.print(prefix); pw.print("mAppToken="); pw.println(mAppToken);
1571a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            }
1572a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            if (mTargetAppToken != null) {
1573a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                pw.print(prefix); pw.print("mTargetAppToken="); pw.println(mTargetAppToken);
1574a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            }
1575a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mViewVisibility=0x");
1576a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(Integer.toHexString(mViewVisibility));
1577a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(" mLastHidden="); pw.print(mLastHidden);
1578a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(" mHaveFrame="); pw.print(mHaveFrame);
1579a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(" mObscured="); pw.println(mObscured);
15806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
15816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mPolicyVisibility || !mPolicyVisibilityAfterAnim || mAttachedHidden) {
15826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mPolicyVisibility=");
15836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(mPolicyVisibility);
15846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mPolicyVisibilityAfterAnim=");
15856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(mPolicyVisibilityAfterAnim);
15866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mAttachedHidden="); pw.println(mAttachedHidden);
15876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
15886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (!mRelayoutCalled) {
15896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mRelayoutCalled="); pw.println(mRelayoutCalled);
15906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
15916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mXOffset != 0 || mYOffset != 0) {
15926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("Offsets x="); pw.print(mXOffset);
15936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" y="); pw.println(mYOffset);
15946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
1595a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        if (dumpAll) {
1596a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mGivenContentInsets=");
1597a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    mGivenContentInsets.printShortString(pw);
1598a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mGivenVisibleInsets=");
1599a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    mGivenVisibleInsets.printShortString(pw);
1600a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.println();
1601a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            if (mTouchableInsets != 0 || mGivenInsetsPending) {
1602a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                pw.print(prefix); pw.print("mTouchableInsets="); pw.print(mTouchableInsets);
1603a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                        pw.print(" mGivenInsetsPending="); pw.println(mGivenInsetsPending);
1604a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            }
1605a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mConfiguration="); pw.println(mConfiguration);
16066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        pw.print(prefix); pw.print("mShownFrame=");
1608b961cd2c80abf1d2834e5ad690904da4fe56d755Dianne Hackborn                mShownFrame.printShortString(pw); pw.println();
1609a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        if (dumpAll) {
1610a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mFrame="); mFrame.printShortString(pw);
1611a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" last="); mLastFrame.printShortString(pw);
1612a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.println();
1613a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        }
1614ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        if (mEnforceSizeCompat) {
1615ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn            pw.print(prefix); pw.print("mCompatFrame="); mCompatFrame.printShortString(pw);
1616ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn                    pw.println();
1617ffb3d939cc78cae523f14a0f8ab37061b5bffc20Dianne Hackborn        }
1618a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        if (dumpAll) {
1619a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mContainingFrame=");
1620a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    mContainingFrame.printShortString(pw);
1621a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mParentFrame=");
1622a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    mParentFrame.printShortString(pw);
1623a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mDisplayFrame=");
1624a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    mDisplayFrame.printShortString(pw);
1625a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.println();
1626a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mContentFrame="); mContentFrame.printShortString(pw);
1627a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mVisibleFrame="); mVisibleFrame.printShortString(pw);
1628a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.println();
1629a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mContentInsets="); mContentInsets.printShortString(pw);
1630a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" last="); mLastContentInsets.printShortString(pw);
1631a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mVisibleInsets="); mVisibleInsets.printShortString(pw);
1632a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" last="); mLastVisibleInsets.printShortString(pw);
1633a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.println();
1634a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        }
16356e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mAnimating || mLocalAnimating || mAnimationIsEntrance
16366e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                || mAnimation != null) {
16376e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mAnimating="); pw.print(mAnimating);
16386e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mLocalAnimating="); pw.print(mLocalAnimating);
16396e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mAnimationIsEntrance="); pw.print(mAnimationIsEntrance);
16406e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mAnimation="); pw.println(mAnimation);
16416e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16426e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mHasTransformation || mHasLocalTransformation) {
16436e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("XForm: has=");
16446e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(mHasTransformation);
16456e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" hasLocal="); pw.print(mHasLocalTransformation);
16466e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" "); mTransformation.printShortString(pw);
16476e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.println();
16486e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16496e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mShownAlpha != 1 || mAlpha != 1 || mLastAlpha != 1) {
16506e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mShownAlpha="); pw.print(mShownAlpha);
16516e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mAlpha="); pw.print(mAlpha);
16526e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mLastAlpha="); pw.println(mLastAlpha);
16536e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
1654e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn        if (mHaveMatrix || mGlobalScale != 1) {
1655e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn            pw.print(prefix); pw.print("mGlobalScale="); pw.print(mGlobalScale);
1656e2515eebf42c763c0a2d9f873a153711778cfc17Dianne Hackborn                    pw.print(" mDsDx="); pw.print(mDsDx);
16576e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mDtDx="); pw.print(mDtDx);
16586e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mDsDy="); pw.print(mDsDy);
16596e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mDtDy="); pw.println(mDtDy);
16606e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
1661a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        if (dumpAll) {
1662a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn            pw.print(prefix); pw.print("mDrawPending="); pw.print(mDrawPending);
1663a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mCommitDrawPending="); pw.print(mCommitDrawPending);
1664a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mReadyToShow="); pw.print(mReadyToShow);
1665a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn                    pw.print(" mHasDrawn="); pw.println(mHasDrawn);
1666a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn        }
16676e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mExiting || mRemoveOnExit || mDestroying || mRemoved) {
16686e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mExiting="); pw.print(mExiting);
16696e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mRemoveOnExit="); pw.print(mRemoveOnExit);
16706e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mDestroying="); pw.print(mDestroying);
16716e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mRemoved="); pw.println(mRemoved);
16726e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16736e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mOrientationChanging || mAppFreezing || mTurnOnScreen) {
16746e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mOrientationChanging=");
16756e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(mOrientationChanging);
16766e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mAppFreezing="); pw.print(mAppFreezing);
16776e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mTurnOnScreen="); pw.println(mTurnOnScreen);
16786e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16796e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mHScale != 1 || mVScale != 1) {
16806e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mHScale="); pw.print(mHScale);
16816e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mVScale="); pw.println(mVScale);
16826e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16836e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mWallpaperX != -1 || mWallpaperY != -1) {
16846e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mWallpaperX="); pw.print(mWallpaperX);
16856e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mWallpaperY="); pw.println(mWallpaperY);
16866e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16876e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mWallpaperXStep != -1 || mWallpaperYStep != -1) {
16886e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            pw.print(prefix); pw.print("mWallpaperXStep="); pw.print(mWallpaperXStep);
16896e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    pw.print(" mWallpaperYStep="); pw.println(mWallpaperYStep);
16906e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
16916e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
16926e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
16936e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    String makeInputChannelName() {
16946e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return Integer.toHexString(System.identityHashCode(this))
16956e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            + " " + mAttrs.getTitle();
16966e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
16976e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn
16986e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    @Override
16996e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    public String toString() {
17006e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        if (mStringNameCache == null || mLastTitle != mAttrs.getTitle()
17016e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                || mWasPaused != mToken.paused) {
17026e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mLastTitle = mAttrs.getTitle();
17036e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mWasPaused = mToken.paused;
17046e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn            mStringNameCache = "Window{" + Integer.toHexString(System.identityHashCode(this))
17056e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn                    + " " + mLastTitle + " paused=" + mWasPaused + "}";
17066e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        }
17076e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn        return mStringNameCache;
17086e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn    }
17096e1eb76f02ccc9dbc309b938f62d39312da8cafeDianne Hackborn}