19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License. 69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at 79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and 149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License. 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.view; 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 19a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brownimport android.app.Presentation; 20a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brownimport android.content.Context; 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ActivityInfo; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.PixelFormat; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.IBinder; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcel; 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcelable; 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.text.TextUtils; 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.Log; 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The interface that apps use to talk to the window manager. 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p> 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Use <code>Context.getSystemService(Context.WINDOW_SERVICE)</code> to get one of these. 34a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p><p> 35a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * Each window manager instance is bound to a particular {@link Display}. 36a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * To obtain a {@link WindowManager} for a different display, use 37a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link Context#createDisplayContext} to obtain a {@link Context} for that 38a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * display, then use <code>Context.getSystemService(Context.WINDOW_SERVICE)</code> 39a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * to get the WindowManager. 40a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p><p> 41a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * The simplest way to show a window on another display is to create a 42a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link Presentation}. The presentation will automatically obtain a 43a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link WindowManager} and {@link Context} for that display. 44a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p> 459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.content.Context#getSystemService 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.content.Context#WINDOW_SERVICE 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic interface WindowManager extends ViewManager { 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Exception that is thrown when trying to add view whose 529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams} {@link WindowManager.LayoutParams#token} 539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is invalid. 549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static class BadTokenException extends RuntimeException { 569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public BadTokenException() { 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public BadTokenException(String name) { 609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(name); 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 656018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner * Exception that is thrown when calling {@link #addView} to a secondary display that cannot 666018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner * be found. See {@link android.app.Presentation} for more information on secondary displays. 676018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner */ 686018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner public static class InvalidDisplayException extends RuntimeException { 696018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner public InvalidDisplayException() { 706018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner } 716018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner 726018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner public InvalidDisplayException(String name) { 736018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner super(name); 746018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner } 756018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner } 766018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner 776018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner /** 78a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * Returns the {@link Display} upon which this {@link WindowManager} instance 79a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * will create new windows. 80a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * <p> 81a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * Despite the name of this method, the display that is returned is not 82a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * necessarily the primary display of the system (see {@link Display#DEFAULT_DISPLAY}). 83a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * The returned display could instead be a secondary display that this 84a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * window manager instance is managing. Think of it as the display that 85a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * this {@link WindowManager} instance uses by default. 86a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p><p> 87a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * To create windows on a different display, you need to obtain a 88a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link WindowManager} for that {@link Display}. (See the {@link WindowManager} 89a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * class documentation for more information.) 90a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p> 91a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * 92a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * @return The display that this window manager is managing. 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public Display getDefaultDisplay(); 95a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Special variation of {@link #removeView} that immediately invokes 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the given view hierarchy's {@link View#onDetachedFromWindow() 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * View.onDetachedFromWindow()} methods before returning. This is not 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * for normal applications; using it correctly requires great care. 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The view to be removed. 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void removeViewImmediate(View view); 105d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static class LayoutParams extends ViewGroup.LayoutParams 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implements Parcelable { 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * X position for this window. With the default gravity it is ignored. 1109e3b002d3f9141d54948a65e0330fdcd09e75a30Fabrice Di Meglio * When using {@link Gravity#LEFT} or {@link Gravity#START} or {@link Gravity#RIGHT} or 1119e3b002d3f9141d54948a65e0330fdcd09e75a30Fabrice Di Meglio * {@link Gravity#END} it provides an offset from the given edge. 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 113529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int x; 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Y position for this window. With the default gravity it is ignored. 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When using {@link Gravity#TOP} or {@link Gravity#BOTTOM} it provides 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an offset from the given edge. 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 121529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int y; 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates how much of the extra space will be allocated horizontally 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to the view associated with these LayoutParams. Specify 0 if the view 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * should not be stretched. Otherwise the extra pixels will be pro-rated 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * among all views whose weight is greater than 0. 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 130529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float horizontalWeight; 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates how much of the extra space will be allocated vertically 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to the view associated with these LayoutParams. Specify 0 if the view 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * should not be stretched. Otherwise the extra pixels will be pro-rated 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * among all views whose weight is greater than 0. 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 139529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float verticalWeight; 141529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The general type of window. There are three main classes of 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window types: 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <ul> 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> <strong>Application windows</strong> (ranging from 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FIRST_APPLICATION_WINDOW} to 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #LAST_APPLICATION_WINDOW}) are normal top-level application 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows. For these types of windows, the {@link #token} must be 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set to the token of the activity they are a part of (this will 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * normally be done for you if {@link #token} is null). 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> <strong>Sub-windows</strong> (ranging from 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FIRST_SUB_WINDOW} to 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #LAST_SUB_WINDOW}) are associated with another top-level 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window. For these types of windows, the {@link #token} must be 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the token of the window it is attached to. 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> <strong>System windows</strong> (ranging from 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FIRST_SYSTEM_WINDOW} to 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #LAST_SYSTEM_WINDOW}) are special types of windows for 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * use by the system for specific purposes. They should not normally 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be used by applications, and a special permission is required 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to use them. 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * </ul> 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_BASE_APPLICATION 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_STARTING 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_PANEL 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_MEDIA 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_SUB_PANEL 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_ATTACHED_DIALOG 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_STATUS_BAR 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SEARCH_BAR 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_PHONE 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_ALERT 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_KEYGUARD 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_TOAST 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_OVERLAY 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_PRIORITY_PHONE 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_STATUS_BAR_PANEL 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_DIALOG 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_KEYGUARD_DIALOG 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_ERROR 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_INPUT_METHOD 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_INPUT_METHOD_DIALOG 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1878f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.ExportedProperty(mapping = { 1888f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_BASE_APPLICATION, to = "TYPE_BASE_APPLICATION"), 1898f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION, to = "TYPE_APPLICATION"), 1908f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_STARTING, to = "TYPE_APPLICATION_STARTING"), 1918f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_PANEL, to = "TYPE_APPLICATION_PANEL"), 1928f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_MEDIA, to = "TYPE_APPLICATION_MEDIA"), 1938f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_SUB_PANEL, to = "TYPE_APPLICATION_SUB_PANEL"), 1948f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_ATTACHED_DIALOG, to = "TYPE_APPLICATION_ATTACHED_DIALOG"), 195aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_APPLICATION_MEDIA_OVERLAY, to = "TYPE_APPLICATION_MEDIA_OVERLAY"), 1968f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_STATUS_BAR, to = "TYPE_STATUS_BAR"), 1978f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SEARCH_BAR, to = "TYPE_SEARCH_BAR"), 1988f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_PHONE, to = "TYPE_PHONE"), 1998f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_ALERT, to = "TYPE_SYSTEM_ALERT"), 2008f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_KEYGUARD, to = "TYPE_KEYGUARD"), 2018f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_TOAST, to = "TYPE_TOAST"), 2028f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_OVERLAY, to = "TYPE_SYSTEM_OVERLAY"), 2038f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_PRIORITY_PHONE, to = "TYPE_PRIORITY_PHONE"), 2048f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_DIALOG, to = "TYPE_SYSTEM_DIALOG"), 2058f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_KEYGUARD_DIALOG, to = "TYPE_KEYGUARD_DIALOG"), 2068f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_ERROR, to = "TYPE_SYSTEM_ERROR"), 2078f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_INPUT_METHOD, to = "TYPE_INPUT_METHOD"), 2083b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown @ViewDebug.IntToString(from = TYPE_INPUT_METHOD_DIALOG, to = "TYPE_INPUT_METHOD_DIALOG"), 209bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_WALLPAPER, to = "TYPE_WALLPAPER"), 210bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_STATUS_BAR_PANEL, to = "TYPE_STATUS_BAR_PANEL"), 21129aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn @ViewDebug.IntToString(from = TYPE_SECURE_SYSTEM_OVERLAY, to = "TYPE_SECURE_SYSTEM_OVERLAY"), 212bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_DRAG, to = "TYPE_DRAG"), 213bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_STATUS_BAR_SUB_PANEL, to = "TYPE_STATUS_BAR_SUB_PANEL"), 214bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_POINTER, to = "TYPE_POINTER"), 215bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_NAVIGATION_BAR, to = "TYPE_NAVIGATION_BAR"), 216bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_VOLUME_OVERLAY, to = "TYPE_VOLUME_OVERLAY"), 217aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_BOOT_PROGRESS, to = "TYPE_BOOT_PROGRESS"), 218aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_HIDDEN_NAV_CONSUMER, to = "TYPE_HIDDEN_NAV_CONSUMER"), 219aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_DREAM, to = "TYPE_DREAM"), 220bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown @ViewDebug.IntToString(from = TYPE_NAVIGATION_BAR_PANEL, to = "TYPE_NAVIGATION_BAR_PANEL"), 2211cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov @ViewDebug.IntToString(from = TYPE_DISPLAY_OVERLAY, to = "TYPE_DISPLAY_OVERLAY"), 2221cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov @ViewDebug.IntToString(from = TYPE_MAGNIFICATION_OVERLAY, to = "TYPE_MAGNIFICATION_OVERLAY") 2238f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato }) 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int type; 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of window types that represent normal application windows. 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_APPLICATION_WINDOW = 1; 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: an application window that serves as the "base" window 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the overall application; all other application windows will 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * appear on top of it. 2355962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows only on the owning user's window. 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_BASE_APPLICATION = 1; 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a normal application window. The {@link #token} must be 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an Activity token identifying who the window belongs to. 2425962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows only on the owning user's window. 2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION = 2; 2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: special application window that is displayed while the 2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application is starting. Not for use by applications themselves; 2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this is used by the system to display something until the 2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application can show its own windows. 2515962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows on all users' windows. 2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_STARTING = 3; 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of application windows. 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_APPLICATION_WINDOW = 99; 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of types of sub-windows. The {@link #token} of these windows 2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * must be set to the window they are attached to. These types of 2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are kept next to their attached window in Z-order, and their 2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * coordinate space is relative to their attached window. 2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_SUB_WINDOW = 1000; 2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a panel on top of an application window. These windows 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * appear on top of their attached window. 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_PANEL = FIRST_SUB_WINDOW; 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 27533291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * Window type: window for showing media (such as video). These windows 2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are displayed behind their attached window. 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_MEDIA = FIRST_SUB_WINDOW+1; 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a sub-panel on top of an application window. These 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are displayed on top their attached window and any 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #TYPE_APPLICATION_PANEL} panels. 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_SUB_PANEL = FIRST_SUB_WINDOW+2; 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window type: like {@link #TYPE_APPLICATION_PANEL}, but layout 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the window happens as that of a top-level window, <em>not</em> 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * as a child of its container. 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_ATTACHED_DIALOG = FIRST_SUB_WINDOW+3; 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 294c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * Window type: window for showing overlays on top of media windows. 295c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * These windows are displayed between TYPE_APPLICATION_MEDIA and the 296c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * application window. They should be translucent to be useful. This 297c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * is a big ugly hack so: 298c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * @hide 299c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn */ 300c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn public static final int TYPE_APPLICATION_MEDIA_OVERLAY = FIRST_SUB_WINDOW+4; 301c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn 302c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn /** 3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of sub-windows. 3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_SUB_WINDOW = 1999; 3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of system-specific window types. These are not normally 3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * created by applications. 3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_SYSTEM_WINDOW = 2000; 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: the status bar. There can be only one status bar 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window; it is placed at the top of the screen, and all other 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are shifted down so they are below it. 31788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_STATUS_BAR = FIRST_SYSTEM_WINDOW; 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: the search bar. There can be only one search bar 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window; it is placed at the top of the screen. 32488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SEARCH_BAR = FIRST_SYSTEM_WINDOW+1; 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: phone. These are non-application windows providing 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user interaction with the phone (in particular incoming calls). 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * These windows are normally placed above all applications, but behind 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the status bar. 33388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_PHONE = FIRST_SYSTEM_WINDOW+2; 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: system window, such as low power alert. These windows 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are always on top of application windows. 34088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_ALERT = FIRST_SYSTEM_WINDOW+3; 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: keyguard window. 34688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_KEYGUARD = FIRST_SYSTEM_WINDOW+4; 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: transient notifications. 35288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_TOAST = FIRST_SYSTEM_WINDOW+5; 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: system overlay windows, which need to be displayed 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * on top of everything else. These windows must not take input 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus, or they will interfere with the keyguard. 36088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_OVERLAY = FIRST_SYSTEM_WINDOW+6; 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: priority phone UI, which needs to be displayed even if 3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the keyguard is active. These windows must not take input 3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus, or they will interfere with the keyguard. 36888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_PRIORITY_PHONE = FIRST_SYSTEM_WINDOW+7; 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: panel that slides out from the status bar 37488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_DIALOG = FIRST_SYSTEM_WINDOW+8; 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: dialogs that the keyguard shows 38088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_KEYGUARD_DIALOG = FIRST_SYSTEM_WINDOW+9; 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal system error windows, appear on top of 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * everything they can. 38788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_ERROR = FIRST_SYSTEM_WINDOW+10; 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal input methods windows, which appear above 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the normal UI. Application windows may be resized or panned to keep 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the input focus visible while this window is displayed. 39588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_INPUT_METHOD = FIRST_SYSTEM_WINDOW+11; 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal input methods dialog windows, which appear above 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the current input method window. 40288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_INPUT_METHOD_DIALOG= FIRST_SYSTEM_WINDOW+12; 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4074c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * Window type: wallpaper window, placed behind any window that wants 4084c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * to sit on top of the wallpaper. 40988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4104c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 4114c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int TYPE_WALLPAPER = FIRST_SYSTEM_WINDOW+13; 4124c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn 4134c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn /** 41429fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato * Window type: panel that slides out from over the status bar 41588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 416badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn */ 417badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn public static final int TYPE_STATUS_BAR_PANEL = FIRST_SYSTEM_WINDOW+14; 4183b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown 4193b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown /** 4203b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * Window type: secure system overlay windows, which need to be displayed 4213b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * on top of everything else. These windows must not take input 4223b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * focus, or they will interfere with the keyguard. 4233b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * 4243b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * This is exactly like {@link #TYPE_SYSTEM_OVERLAY} except that only the 4253b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * system itself is allowed to create these overlays. Applications cannot 4263b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * obtain permission to create secure system overlays. 42788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * 42888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4293b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * @hide 4303b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown */ 4313b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown public static final int TYPE_SECURE_SYSTEM_OVERLAY = FIRST_SYSTEM_WINDOW+15; 4323b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown 433badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn /** 434a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * Window type: the drag-and-drop pseudowindow. There is only one 435a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * drag layer (at most), and it is placed on top of all other windows. 43688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 437a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * @hide 438a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate */ 4393b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown public static final int TYPE_DRAG = FIRST_SYSTEM_WINDOW+16; 440a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate 441a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate /** 44229fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato * Window type: panel that slides out from under the status bar 44388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 444a89e903fd4b84778e1a7f2268fe025fe66a6e45eJoe Onorato * @hide 44529fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato */ 44629fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato public static final int TYPE_STATUS_BAR_SUB_PANEL = FIRST_SYSTEM_WINDOW+17; 44729fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato 44883c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown /** 44983c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown * Window type: (mouse) pointer 45088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 45183c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown * @hide 45283c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown */ 45383c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown public static final int TYPE_POINTER = FIRST_SYSTEM_WINDOW+18; 45429fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato 45529fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato /** 4568956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler * Window type: Navigation bar (when distinct from status bar) 45788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 4588956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler * @hide 4598956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler */ 4608956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler public static final int TYPE_NAVIGATION_BAR = FIRST_SYSTEM_WINDOW+19; 4618956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler 4628956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler /** 463e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * Window type: The volume level overlay/dialog shown when the user 464e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * changes the system volume. 46588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 466e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * @hide 467e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn */ 468e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn public static final int TYPE_VOLUME_OVERLAY = FIRST_SYSTEM_WINDOW+20; 469e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn 470e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn /** 47129aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * Window type: The boot progress dialog, goes on top of everything 47229aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * in the world. 47388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 47429aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * @hide 47529aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn */ 47629aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn public static final int TYPE_BOOT_PROGRESS = FIRST_SYSTEM_WINDOW+21; 47729aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn 47829aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn /** 479df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * Window type: Fake window to consume touch events when the navigation 480df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * bar is hidden. 48188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 482df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * @hide 483df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn */ 484df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn public static final int TYPE_HIDDEN_NAV_CONSUMER = FIRST_SYSTEM_WINDOW+22; 485df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn 486df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn /** 4877d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler * Window type: Dreams (screen saver) window, just above keyguard. 48888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4897d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler * @hide 4907d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler */ 4917d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler public static final int TYPE_DREAM = FIRST_SYSTEM_WINDOW+23; 4927d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler 4937d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler /** 494e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller * Window type: Navigation bar panel (when navigation bar is distinct from status bar) 49588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 496e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller * @hide 497e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller */ 498e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller public static final int TYPE_NAVIGATION_BAR_PANEL = FIRST_SYSTEM_WINDOW+24; 499e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller 500e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller /** 501a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn * Window type: Behind the universe of the real windows. 50288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 503a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn * @hide 504a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn */ 505a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn public static final int TYPE_UNIVERSE_BACKGROUND = FIRST_SYSTEM_WINDOW+25; 506a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn 507a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn /** 508bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown * Window type: Display overlay window. Used to simulate secondary display devices. 50988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 510bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown * @hide 511bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown */ 512bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown public static final int TYPE_DISPLAY_OVERLAY = FIRST_SYSTEM_WINDOW+26; 513bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown 514bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown /** 5151cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * Window type: Magnification overlay window. Used to highlight the magnified 5161cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * portion of a display when accessibility magnification is enabled. 51788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 5181cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * @hide 5191cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov */ 5201cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov public static final int TYPE_MAGNIFICATION_OVERLAY = FIRST_SYSTEM_WINDOW+27; 5211cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov 5221cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov /** 52388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * Window type: Recents. Same layer as {@link #TYPE_SYSTEM_DIALOG} but only appears on 52488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * one user's screen. 52588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 52688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * @hide 52788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner */ 52888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner public static final int TYPE_RECENTS_OVERLAY = FIRST_SYSTEM_WINDOW+28; 52988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner 53088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner /** 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of system windows. 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_SYSTEM_WINDOW = 2999; 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 535d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 536d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian @Deprecated 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_NORMAL = 0; 538d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 539317a6280cc109e873646e4652be1582d870eedfdMathias Agopian @Deprecated 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_HARDWARE = 1; 541d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 542317a6280cc109e873646e4652be1582d870eedfdMathias Agopian @Deprecated 5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_GPU = 2; 544d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 545d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian @Deprecated 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_PUSH_BUFFERS = 3; 5475d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5495d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @deprecated this is ignored 5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5515d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @Deprecated 5525d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int memoryType; 5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 554ef73162887943e16587b8e737b19e59348338e8cMike Lockwood /** Window flag: as long as this window is visible to the user, allow 555ef73162887943e16587b8e737b19e59348338e8cMike Lockwood * the lock screen to activate while the screen is on. 556ef73162887943e16587b8e737b19e59348338e8cMike Lockwood * This can be used independently, or in combination with 55795f7850a9d9c7c4f020d06986300f4740fb6a52cChristopher Tate * {@link #FLAG_KEEP_SCREEN_ON} and/or {@link #FLAG_SHOW_WHEN_LOCKED} */ 558ef73162887943e16587b8e737b19e59348338e8cMike Lockwood public static final int FLAG_ALLOW_LOCK_WHILE_SCREEN_ON = 0x00000001; 559ef73162887943e16587b8e737b19e59348338e8cMike Lockwood 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: everything behind this window will be dimmed. 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Use {@link #dimAmount} to control the amount of dim. */ 5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_DIM_BEHIND = 0x00000002; 5635d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5645d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** Window flag: blur everything behind this window. 5655d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @deprecated Blurring is no longer supported. */ 5665d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @Deprecated 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_BLUR_BEHIND = 0x00000004; 5685d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: this window won't ever get key input focus, so the 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user can not send key or other button events to it. Those will 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * instead go to whatever focusable window is behind it. This flag 5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will also enable {@link #FLAG_NOT_TOUCH_MODAL} whether or not that 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is explicitly set. 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>Setting this flag also implies that the window will not need to 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * interact with 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * a soft input method, so it will be Z-ordered and positioned 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * independently of any active input method (typically this means it 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * gets Z-ordered on top of the input method, so it can use the full 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen for its content and cover the input method if needed. You 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can use {@link #FLAG_ALT_FOCUSABLE_IM} to modify this behavior. */ 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_FOCUSABLE = 0x00000008; 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: this window can never receive touch events. */ 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_TOUCHABLE = 0x00000010; 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 58733291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: even when this window is focusable (its 58833291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * {@link #FLAG_NOT_FOCUSABLE} is not set), allow any pointer events 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * outside of the window to be sent to the windows behind it. Otherwise 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * it will consume all pointer events itself, regardless of whether they 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are inside of the window. */ 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_TOUCH_MODAL = 0x00000020; 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 59433291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: when set, if the device is asleep when the touch 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen is pressed, you will receive this first touch event. Usually 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the first touch event is consumed by the system since the user can 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not see what they are pressing on. 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_TOUCHABLE_WHEN_WAKING = 0x00000040; 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: as long as this window is visible to the user, keep 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the device's screen turned on and bright. */ 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_KEEP_SCREEN_ON = 0x00000080; 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: place the window within the entire screen, ignoring 60633291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * decorations around the border (such as the status bar). The 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window must correctly position its contents to take the screen 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * decoration into account. This flag is normally set for you 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * by Window as described in {@link Window#setFlags}. */ 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_IN_SCREEN = 0x00000100; 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: allow window to extend outside of the screen. */ 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_NO_LIMITS = 0x00000200; 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6151bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn /** 61633291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * Window flag: hide all screen decorations (such as the status bar) while 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this window is displayed. This allows the window to use the entire 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * display space for itself -- the status bar will be hidden when 61945c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * an app window with this flag set is on the top layer. A fullscreen window 62045c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * will ignore a value of {@link #SOFT_INPUT_ADJUST_RESIZE} for the window's 62145c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * {@link #softInputMode} field; the window will stay fullscreen 62245c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * and will not resize. 6231bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 6241bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 6251bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowFullscreen} attribute; this attribute 6261bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * is automatically set for you in the standard fullscreen themes 6271bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * such as {@link android.R.style#Theme_NoTitleBar_Fullscreen}, 6281bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Black_NoTitleBar_Fullscreen}, 6291bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Light_NoTitleBar_Fullscreen}, 6301bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_NoActionBar_Fullscreen}, 6311bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Light_NoActionBar_Fullscreen}, 6321bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_NoActionBar_Fullscreen}, and 6331bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Light_NoActionBar_Fullscreen}.</p> 6341bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn */ 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_FULLSCREEN = 0x00000400; 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 63733291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: override {@link #FLAG_FULLSCREEN} and force the 63833291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * screen decorations (such as the status bar) to be shown. */ 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_FORCE_NOT_FULLSCREEN = 0x00000800; 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: turn on dithering when compositing this window to 6423cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown * the screen. 6433cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown * @deprecated This flag is no longer used. */ 6443cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown @Deprecated 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_DITHER = 0x00001000; 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 64733291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: treat the content of the window as secure, preventing 648f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * it from appearing in screenshots or from being viewed on non-secure 649f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * displays. 650f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * 651f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * <p>See {@link android.view.Display#FLAG_SECURE} for more details about 652f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * secure surfaces and secure displays. 653f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown */ 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SECURE = 0x00002000; 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special mode where the layout parameters are used 6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to perform scaling of the surface when it is composited to the 6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen. */ 6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SCALED = 0x00004000; 6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: intended for windows that will often be used when the user is 6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * holding the screen against their face, it will aggressively filter the event 6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * stream to prevent unintended presses in this situation that may not be 6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * desired for a particular window, when such an event stream is detected, the 6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application will receive a CANCEL motion event to indicate this so applications 6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can handle this accordingly by taking no action on the event 6679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * until the finger is released. */ 6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_IGNORE_CHEEK_PRESSES = 0x00008000; 6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special option only for use in combination with 6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_LAYOUT_IN_SCREEN}. When requesting layout in the 6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen your window may appear on top of or behind screen decorations 6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * such as the status bar. By also including this flag, the window 6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * manager will report the inset rectangle needed to ensure your 6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * content is not covered by screen decorations. This flag is normally 6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set for you by Window as described in {@link Window#setFlags}.*/ 6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_INSET_DECOR = 0x00010000; 6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: invert the state of {@link #FLAG_NOT_FOCUSABLE} with 6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * respect to how this window interacts with the current method. That 6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is, if FLAG_NOT_FOCUSABLE is set and this flag is set, then the 6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window will behave as if it needs to interact with the input method 6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and thus be placed behind/away from it; if FLAG_NOT_FOCUSABLE is 6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not set and this flag is set, then the window will behave as if it 6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * doesn't need to interact with the input method and can be placed 6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to use more space and cover the input method. 6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_ALT_FOCUSABLE_IM = 0x00020000; 6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: if you have set {@link #FLAG_NOT_TOUCH_MODAL}, you 6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can set this flag to receive a single special MotionEvent with 6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the action 6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link MotionEvent#ACTION_OUTSIDE MotionEvent.ACTION_OUTSIDE} for 6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * touches that occur outside of your window. Note that you will not 6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * receive the full down/move/up gesture, only the location of the 6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * first down as an ACTION_OUTSIDE. 6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_WATCH_OUTSIDE_TOUCH = 0x00040000; 6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 700d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu /** Window flag: special flag to let windows be shown when the screen 701d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * is locked. This will let application windows take precedence over 702d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * key guard or any other lock screens. Can be used with 703d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * {@link #FLAG_KEEP_SCREEN_ON} to turn screen on and display windows 7049bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * directly before showing the key guard window. Can be used with 7059bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * {@link #FLAG_DISMISS_KEYGUARD} to automatically fully dismisss 7069bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * non-secure keyguards. This flag only applies to the top-most 7079bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * full-screen window. 7084c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 709d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu public static final int FLAG_SHOW_WHEN_LOCKED = 0x00080000; 710d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu 7114c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn /** Window flag: ask that the system wallpaper be shown behind 7124c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * your window. The window surface must be translucent to be able 7134c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * to actually see the wallpaper behind it; this flag just ensures 7144c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * that the wallpaper surface will be there if this window actually 7154c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * has translucent regions. 7161bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 7171bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 7181bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowShowWallpaper} attribute; this attribute 7191bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * is automatically set for you in the standard wallpaper themes 7201bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * such as {@link android.R.style#Theme_Wallpaper}, 7211bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Wallpaper_NoTitleBar}, 7221bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Wallpaper_NoTitleBar_Fullscreen}, 7231bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Wallpaper}, 7241bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Wallpaper_NoTitleBar}, 7251bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Wallpaper}, and 7261bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Wallpaper_NoTitleBar}.</p> 7274c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 7284c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int FLAG_SHOW_WALLPAPER = 0x00100000; 7294c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn 73093e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn /** Window flag: when set as a window is being added or made 73193e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * visible, once the window has been shown then the system will 73293e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * poke the power manager's user activity (as if the user had woken 73393e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * up the device) to turn the screen on. */ 73493e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn public static final int FLAG_TURN_SCREEN_ON = 0x00200000; 73593e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn 7369bfb707597898f54722460b48588007b682f3e2aDianne Hackborn /** Window flag: when set the window will cause the keyguard to 7379bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * be dismissed, only if it is not a secure lock keyguard. Because such 7389bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * a keyguard is not needed for security, it will never re-appear if 7399bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * the user navigates to another window (in contrast to 7409bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * {@link #FLAG_SHOW_WHEN_LOCKED}, which will only temporarily 7419bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * hide both secure and non-secure keyguards but ensure they reappear 7429bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * when the user moves to another UI that doesn't hide them). 7439bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * If the keyguard is currently active and is secure (requires an 7449bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * unlock pattern) than the user will still need to confirm it before 7459bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * seeing this window, unless {@link #FLAG_SHOW_WHEN_LOCKED} has 746ae069f76ee65fd5d9252c8191429fa55296d0208Daniel Sandler * also been set. 747ae069f76ee65fd5d9252c8191429fa55296d0208Daniel Sandler */ 7489bfb707597898f54722460b48588007b682f3e2aDianne Hackborn public static final int FLAG_DISMISS_KEYGUARD = 0x00400000; 74901ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown 75001ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown /** Window flag: when set the window will accept for touch events 75101ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * outside of its bounds to be sent to other windows that also 75201ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * support split touch. When this flag is not set, the first pointer 75301ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * that goes down determines the window to which all subsequent touches 75401ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * go until all pointers go up. When this flag is set, each pointer 75501ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * (not necessarily the first) that goes down determines the window 75601ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * to which all subsequent touches of that pointer will go until that 75701ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * pointer goes up thereby enabling touches with multiple pointers 75801ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * to be split across multiple windows. 759d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn */ 76001ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown public static final int FLAG_SPLIT_TOUCH = 0x00800000; 761d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn 762d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn /** 76372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>Indicates whether this window should be hardware accelerated. 76472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * Requesting hardware acceleration does not guarantee it will happen.</p> 765c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 76672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag can be controlled programmatically <em>only</em> to enable 76772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * hardware acceleration. To enable hardware acceleration for a given 76872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * window programmatically, do the following:</p> 769c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 77072f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <pre> 77172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * Window w = activity.getWindow(); // in Activity's onCreate() for instance 77272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * w.setFlags(WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED, 77372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED); 77472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * </pre> 775c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 77672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>It is important to remember that this flag <strong>must</strong> 77772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * be set before setting the content view of your activity or dialog.</p> 778c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 77972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag cannot be used to disable hardware acceleration after it 78072f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * was enabled in your manifest using 78172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * {@link android.R.attr#hardwareAccelerated}. If you need to selectively 78272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * and programmatically disable hardware acceleration (for automated testing 78372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * for instance), make sure it is turned off in your manifest and enable it 78472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * on your activity or dialog when you need it instead, using the method 78572f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * described above.</p> 786c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 78772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag is automatically set by the system if the 78872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * {@link android.R.attr#hardwareAccelerated android:hardwareAccelerated} 78972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * XML attribute is set to true on an activity or on the application.</p> 790d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn */ 791d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn public static final int FLAG_HARDWARE_ACCELERATED = 0x01000000; 792611fae4c39edbeb23b53f789a0219c539cf32fa6Daniel Sandler 7931bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn /** 7941bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * Window flag: allow window contents to extend in to the screen's 795c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * overscan area, if there is one. The window should still correctly 796c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * position its contents to take the overscan area into account. 7971bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 7981bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 7991bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowOverscan} attribute; this attribute 8001bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * is automatically set for you in the standard overscan themes 8014e0eb22fdf56b8f3fd1bff09c4064b35b80751c1Ying Wang * such as 8021bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_NoActionBar_Overscan}, 8031bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Light_NoActionBar_Overscan}, 8041bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_NoActionBar_Overscan}, and 8051bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Light_NoActionBar_Overscan}.</p> 8061bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8071bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>When this flag is enabled for a window, its normal content may be obscured 8081bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * to some degree by the overscan region of the display. To ensure key parts of 8091bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * that content are visible to the user, you can use 8101bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link View#setFitsSystemWindows(boolean) View.setFitsSystemWindows(boolean)} 8111bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * to set the point in the view hierarchy where the appropriate offsets should 8121bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * be applied. (This can be done either by directly calling this function, using 8131bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * the {@link android.R.attr#fitsSystemWindows} attribute in your view hierarchy, 8141bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * or implementing you own {@link View#fitSystemWindows(android.graphics.Rect) 8151bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * View.fitSystemWindows(Rect)} method).</p> 8161bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8171bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This mechanism for positioning content elements is identical to its equivalent 8181bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * use with layout and {@link View#setSystemUiVisibility(int) 8191bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * View.setSystemUiVisibility(int)}; here is an example layout that will correctly 8201bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * position its UI elements with this overscan flag is set:</p> 8211bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8221bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@sample development/samples/ApiDemos/res/layout/overscan_activity.xml complete} 823c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn */ 824c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn public static final int FLAG_LAYOUT_IN_OVERSCAN = 0x02000000; 825c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn 826d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn // ----- HIDDEN FLAGS. 827d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn // These start at the high bit and go down. 82898db5fabdad86dca379740d8050697950b9f026cJeff Brown 82998db5fabdad86dca379740d8050697950b9f026cJeff Brown /** Window flag: Enable touches to slide out of a window into neighboring 83098db5fabdad86dca379740d8050697950b9f026cJeff Brown * windows in mid-gesture instead of being captured for the duration of 83198db5fabdad86dca379740d8050697950b9f026cJeff Brown * the gesture. 83298db5fabdad86dca379740d8050697950b9f026cJeff Brown * 83398db5fabdad86dca379740d8050697950b9f026cJeff Brown * This flag changes the behavior of touch focus for this window only. 83498db5fabdad86dca379740d8050697950b9f026cJeff Brown * Touches can slide out of the window but they cannot necessarily slide 83598db5fabdad86dca379740d8050697950b9f026cJeff Brown * back in (unless the other window with touch focus permits it). 83698db5fabdad86dca379740d8050697950b9f026cJeff Brown * 83798db5fabdad86dca379740d8050697950b9f026cJeff Brown * {@hide} 83898db5fabdad86dca379740d8050697950b9f026cJeff Brown */ 83998db5fabdad86dca379740d8050697950b9f026cJeff Brown public static final int FLAG_SLIPPERY = 0x04000000; 84098db5fabdad86dca379740d8050697950b9f026cJeff Brown 841e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler /** 842e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * Flag for a window belonging to an activity that responds to {@link KeyEvent#KEYCODE_MENU} 843e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * and therefore needs a Menu key. For devices where Menu is a physical button this flag is 844e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * ignored, but on devices where the Menu key is drawn in software it may be hidden unless 845e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * this flag is set. 846e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * 847e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * (Note that Action Bars, when available, are the preferred way to offer additional 848e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * functions otherwise accessed via an options menu.) 849e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * 850e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * {@hide} 851e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler */ 852d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn public static final int FLAG_NEEDS_MENU_KEY = 0x08000000; 853e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler 8541ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima /** Window flag: special flag to limit the size of the window to be 8551ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * original size ([320x480] x density). Used to create window for applications 8561ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * running under compatibility mode. 8571ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * 8581ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * {@hide} */ 8594c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int FLAG_COMPATIBLE_WINDOW = 0x20000000; 8601ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima 8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special option intended for system dialogs. When 8629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this flag is set, the window will demand focus unconditionally when 8639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * it is created. 8649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@hide} */ 8659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SYSTEM_ERROR = 0x40000000; 8669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 8685d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Various behavioral options/flags. Default is none. 8695d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 8705d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_ALLOW_LOCK_WHILE_SCREEN_ON 8715d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_DIM_BEHIND 8725d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_FOCUSABLE 8735d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_TOUCHABLE 8745d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_TOUCH_MODAL 8755d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_TOUCHABLE_WHEN_WAKING 8765d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_KEEP_SCREEN_ON 8775d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_IN_SCREEN 8785d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_NO_LIMITS 8795d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_FULLSCREEN 8805d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_FORCE_NOT_FULLSCREEN 8815d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SECURE 8825d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SCALED 8835d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_IGNORE_CHEEK_PRESSES 8845d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_INSET_DECOR 8855d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_ALT_FOCUSABLE_IM 8865d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_WATCH_OUTSIDE_TOUCH 8875d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SHOW_WHEN_LOCKED 8885d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SHOW_WALLPAPER 8895d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_TURN_SCREEN_ON 8905d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_DISMISS_KEYGUARD 8915d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SPLIT_TOUCH 8925d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_HARDWARE_ACCELERATED 8935d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 8945d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.ExportedProperty(flagMapping = { 8955d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_ALLOW_LOCK_WHILE_SCREEN_ON, equals = FLAG_ALLOW_LOCK_WHILE_SCREEN_ON, 8965d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_ALLOW_LOCK_WHILE_SCREEN_ON"), 8975d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DIM_BEHIND, equals = FLAG_DIM_BEHIND, 8985d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DIM_BEHIND"), 8995d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_BLUR_BEHIND, equals = FLAG_BLUR_BEHIND, 9005d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_BLUR_BEHIND"), 9015d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_FOCUSABLE, equals = FLAG_NOT_FOCUSABLE, 9025d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_FOCUSABLE"), 9035d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_TOUCHABLE, equals = FLAG_NOT_TOUCHABLE, 9045d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_TOUCHABLE"), 9055d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_TOUCH_MODAL, equals = FLAG_NOT_TOUCH_MODAL, 9065d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_TOUCH_MODAL"), 9075d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_TOUCHABLE_WHEN_WAKING, equals = FLAG_TOUCHABLE_WHEN_WAKING, 9085d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_TOUCHABLE_WHEN_WAKING"), 9095d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_KEEP_SCREEN_ON, equals = FLAG_KEEP_SCREEN_ON, 9105d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_KEEP_SCREEN_ON"), 9115d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_IN_SCREEN, equals = FLAG_LAYOUT_IN_SCREEN, 9125d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_IN_SCREEN"), 9135d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_NO_LIMITS, equals = FLAG_LAYOUT_NO_LIMITS, 9145d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_NO_LIMITS"), 9155d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_FULLSCREEN, equals = FLAG_FULLSCREEN, 9165d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_FULLSCREEN"), 9175d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_FORCE_NOT_FULLSCREEN, equals = FLAG_FORCE_NOT_FULLSCREEN, 9185d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_FORCE_NOT_FULLSCREEN"), 9195d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DITHER, equals = FLAG_DITHER, 9205d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DITHER"), 9215d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SECURE, equals = FLAG_SECURE, 9225d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SECURE"), 9235d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SCALED, equals = FLAG_SCALED, 9245d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SCALED"), 9255d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_IGNORE_CHEEK_PRESSES, equals = FLAG_IGNORE_CHEEK_PRESSES, 9265d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_IGNORE_CHEEK_PRESSES"), 9275d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_INSET_DECOR, equals = FLAG_LAYOUT_INSET_DECOR, 9285d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_INSET_DECOR"), 9295d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_ALT_FOCUSABLE_IM, equals = FLAG_ALT_FOCUSABLE_IM, 9305d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_ALT_FOCUSABLE_IM"), 9315d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_WATCH_OUTSIDE_TOUCH, equals = FLAG_WATCH_OUTSIDE_TOUCH, 9325d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_WATCH_OUTSIDE_TOUCH"), 9335d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SHOW_WHEN_LOCKED, equals = FLAG_SHOW_WHEN_LOCKED, 9345d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SHOW_WHEN_LOCKED"), 9355d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SHOW_WALLPAPER, equals = FLAG_SHOW_WALLPAPER, 9365d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SHOW_WALLPAPER"), 9375d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_TURN_SCREEN_ON, equals = FLAG_TURN_SCREEN_ON, 9385d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_TURN_SCREEN_ON"), 9395d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DISMISS_KEYGUARD, equals = FLAG_DISMISS_KEYGUARD, 9405d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DISMISS_KEYGUARD"), 9415d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SPLIT_TOUCH, equals = FLAG_SPLIT_TOUCH, 9425d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SPLIT_TOUCH"), 9435d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_HARDWARE_ACCELERATED, equals = FLAG_HARDWARE_ACCELERATED, 9445d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_HARDWARE_ACCELERATED") 9455d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn }) 9465d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int flags; 9475d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 9485d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 9495d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * If the window has requested hardware acceleration, but this is not 9505d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * allowed in the process it is in, then still render it as if it is 9515d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * hardware accelerated. This is used for the starting preview windows 9525d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * in the system process, which don't need to have the overhead of 9535d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * hardware acceleration (they are just a static rendering), but should 954f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * be rendered as such to match the actual window of the app even if it 9555d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * is hardware accelerated. 9565d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Even if the window isn't hardware accelerated, still do its rendering 957f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * as if it was. 9585d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Like {@link #FLAG_HARDWARE_ACCELERATED} except for trusted system windows 9595d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * that need hardware acceleration (e.g. LockScreen), where hardware acceleration 9605d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * is generally disabled. This flag must be specified in addition to 9615d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * {@link #FLAG_HARDWARE_ACCELERATED} to enable hardware acceleration for system 9625d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * windows. 9635d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 9645d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 9655d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 9665d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAG_FAKE_HARDWARE_ACCELERATED = 0x00000001; 9675d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 9685d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 9695d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * In the system process, we globally do not use hardware acceleration 970f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * because there are many threads doing UI there and they conflict. 9715d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * If certain parts of the UI that really do want to use hardware 9725d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * acceleration, this flag can be set to force it. This is basically 9735d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * for the lock screen. Anyone else using it, you are probably wrong. 9745d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 9755d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 9765d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 9775d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAG_FORCE_HARDWARE_ACCELERATED = 0x00000002; 9785d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 9795d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 980a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * By default, wallpapers are sent new offsets when the wallpaper is scrolled. Wallpapers 981f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * may elect to skip these notifications if they are not doing anything productive with 982a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * them (they do not affect the wallpaper scrolling operation) by calling 983a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * {@link 984a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * android.service.wallpaper.WallpaperService.Engine#setOffsetNotificationsEnabled(boolean)}. 985a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * 986a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * @hide 987a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase */ 988a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase public static final int PRIVATE_FLAG_WANTS_OFFSET_NOTIFICATIONS = 0x00000004; 989a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase 990a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase /** 99173ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * This is set for a window that has explicitly specified its 99273ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * FLAG_NEEDS_MENU_KEY, so we know the value on this window is the 99373ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * appropriate one to use. If this is not set, we should look at 99473ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * windows behind it to determine the appropriate value. 99573ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * 99673ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * @hide 99773ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn */ 99873ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn public static final int PRIVATE_FLAG_SET_NEEDS_MENU_KEY = 0x00000008; 99973ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn 100088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner /** In a multiuser system if this flag is set and the owner is a system process then this 100188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * window will appear on all user screens. This overrides the default behavior of window 100288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * types that normally only appear on the owning user's screen. Refer to each window type 100388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * to determine its default behavior. 100488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * 100588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * {@hide} */ 100688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner public static final int PRIVATE_FLAG_SHOW_FOR_ALL_USERS = 0x00000010; 100788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner 100873ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn /** 1009891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * Special flag for the volume overlay: force the window manager out of "hide nav bar" 1010891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * mode while the window is on screen. 1011891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * 1012891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * {@hide} */ 1013891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn public static final int PRIVATE_FLAG_FORCE_SHOW_NAV_BAR = 0x00000020; 1014891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn 1015891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn /** 10161c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn * Never animate position changes of the window. 10171c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn * 10181c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn * {@hide} */ 10191c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn public static final int PRIVATE_FLAG_NO_MOVE_ANIMATION = 0x00000040; 10201c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn 10211c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn /** 10225d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Control flags that are private to the platform. 10235d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 10245d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 10255d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int privateFlags; 10265d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 10275d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 10289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Given a particular set of window manager flags, determine whether 10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * such a window may be a target for an input method when it has 10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus. In particular, this checks the 10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_NOT_FOCUSABLE} and {@link #FLAG_ALT_FOCUSABLE_IM} 10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * flags and returns true if the combination of the two corresponds 10339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to a window that needs to be behind the input method so that the 10349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user can type into it. 10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags The current window manager flags. 10379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Returns true if such a window should be behind/interact 10399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * with an input method, false if not. 10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean mayUseInputMethod(int flags) { 10429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project switch (flags&(FLAG_NOT_FOCUSABLE|FLAG_ALT_FOCUSABLE_IM)) { 10439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case 0: 10449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case FLAG_NOT_FOCUSABLE|FLAG_ALT_FOCUSABLE_IM: 10459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 10469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Mask for {@link #softInputMode} of the bits that determine the 10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * desired visibility state of the soft input area for this window. 10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MASK_STATE = 0x0f; 10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: no state has been specified. 10589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_UNSPECIFIED = 0; 10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please don't change the state of 10639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the soft input area. 10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_UNCHANGED = 1; 10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please hide any soft input 10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * area when normally appropriate (when the user is navigating 10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to your window). 10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_HIDDEN = 2; 10739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please always hide any 10769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * soft input area when this window receives focus. 10779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_ALWAYS_HIDDEN = 3; 10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please show the soft 10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * input area when normally appropriate (when the user is navigating 10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to your window). 10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_VISIBLE = 4; 10869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please always make the 10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * soft input area visible when this window receives input focus. 10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_ALWAYS_VISIBLE = 5; 10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Mask for {@link #softInputMode} of the bits that determine the 10959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * way that the window should be adjusted to accommodate the soft 10969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * input window. 10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MASK_ADJUST = 0xf0; 10999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: nothing specified. 11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The system will try to pick one or 11029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 11039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_UNSPECIFIED = 0x00; 11059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: set to allow the 11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window to be resized when an input 11089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * method is shown, so that its contents are not covered by the input 1109f10e6331e3bf01653235d93aa523056c146a85a3Scott Main * method. This can <em>not</em> be combined with 11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_PAN}; if 11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * neither of these are set, then the system will try to pick one or 111245c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * the other depending on the contents of the window. If the window's 111345c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * layout parameter flags include {@link #FLAG_FULLSCREEN}, this 111445c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * value for {@link #softInputMode} will be ignored; the window will 111545c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * not resize, but will stay fullscreen. 11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_RESIZE = 0x10; 11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: set to have a window 11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * pan when an input method is 11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * shown, so it doesn't need to deal with resizing but just panned 11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * by the framework to ensure the current input focus is visible. This 1123f10e6331e3bf01653235d93aa523056c146a85a3Scott Main * can <em>not</em> be combined with {@link #SOFT_INPUT_ADJUST_RESIZE}; if 11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * neither of these are set, then the system will try to pick one or 11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_PAN = 0x20; 11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1129dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** Adjustment option for {@link #softInputMode}: set to have a window 1130dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * not adjust for a shown input method. The window will not be resized, 1131dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * and it will not be panned to make its focus visible. 1132dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1133dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final int SOFT_INPUT_ADJUST_NOTHING = 0x30; 1134dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Bit for {@link #softInputMode}: set when the user has navigated 11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to the window. This is normally set automatically for 11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you by the system, though you may want to set it in certain cases 11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * when you are displaying a window yourself. This flag will always 11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be cleared automatically after the window is displayed. 11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_IS_FORWARD_NAVIGATION = 0x100; 1143fb73f79340375013225618a5d87f46b958f698efMike Lockwood 1144fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** 1145be2c4f92a990ca48ad6ede252343dd9574dfe505Gilles Debunne * Desired operating mode for any soft input area. May be any combination 11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of: 11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <ul> 11499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> One of the visibility states 11509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_UNSPECIFIED}, {@link #SOFT_INPUT_STATE_UNCHANGED}, 11519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_HIDDEN}, {@link #SOFT_INPUT_STATE_ALWAYS_VISIBLE}, or 11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_VISIBLE}. 11539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> One of the adjustment options 11549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_UNSPECIFIED}, 11559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_RESIZE}, or 11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_PAN}. 11571bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * </ul> 11581bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 11591bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 11601bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 11611bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowSoftInputMode} attribute.</p> 11629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int softInputMode; 11649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11668eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Placement of window within the screen as per {@link Gravity}. Both 11678eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 11688eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} and 11698eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#applyDisplay(int, android.graphics.Rect, android.graphics.Rect) 11708eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Gravity.applyDisplay} are used during window layout, with this value 11718eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * given as the desired gravity. For example you can specify 11728eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#DISPLAY_CLIP_HORIZONTAL Gravity.DISPLAY_CLIP_HORIZONTAL} and 11738eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#DISPLAY_CLIP_VERTICAL Gravity.DISPLAY_CLIP_VERTICAL} here 11748eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * to control the behavior of 11758eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#applyDisplay(int, android.graphics.Rect, android.graphics.Rect) 11768eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Gravity.applyDisplay}. 11779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see Gravity 11799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int gravity; 11819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The horizontal margin, as a percentage of the container's width, 11848eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * between the container and the widget. See 11858eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 11868eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} for how this is used. This 11878eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * field is added with {@link #x} to supply the <var>xAdj</var> parameter. 11889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float horizontalMargin; 11909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The vertical margin, as a percentage of the container's height, 11938eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * between the container and the widget. See 11948eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 11958eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} for how this is used. This 11968eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * field is added with {@link #y} to supply the <var>yAdj</var> parameter. 11979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float verticalMargin; 11999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The desired bitmap format. May be one of the constants in 12029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.graphics.PixelFormat}. Default is OPAQUE. 12039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int format; 12059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * A style resource defining the animations to use for this window. 12089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This must be a system resource; it can not be an application resource 12099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * because the window manager does not have access to applications. 12109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int windowAnimations; 12129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An alpha value to apply to this entire window. 12159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An alpha of 1.0 means fully opaque and 0.0 means fully transparent 12169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float alpha = 1.0f; 12189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When {@link #FLAG_DIM_BEHIND} is set, this is the amount of dimming 12219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to apply. Range is from 1.0 for completely opaque to 0.0 for no 12229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * dim. 12239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float dimAmount = 1.0f; 1225dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1226dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1227dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Default value for {@link #screenBrightness} and {@link #buttonBrightness} 1228dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the brightness value is not overridden for this window 1229dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * and normal brightness policy should be used. 1230dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1231dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_NONE = -1.0f; 1232dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1233dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1234dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Value for {@link #screenBrightness} and {@link #buttonBrightness} 1235dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the screen or button backlight brightness should be set 1236dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * to the lowest value when this window is in front. 1237dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1238dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_OFF = 0.0f; 1239dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1240dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1241dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Value for {@link #screenBrightness} and {@link #buttonBrightness} 1242dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the screen or button backlight brightness should be set 1243dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * to the hightest value when this window is in front. 1244dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1245dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_FULL = 1.0f; 12469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This can be used to override the user's preferred brightness of 12499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the screen. A value of less than 0, the default, means to use the 12509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * preferred screen brightness. 0 to 1 adjusts the brightness from 12519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * dark to full bright. 12529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1253fb73f79340375013225618a5d87f46b958f698efMike Lockwood public float screenBrightness = BRIGHTNESS_OVERRIDE_NONE; 12549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1256fb73f79340375013225618a5d87f46b958f698efMike Lockwood * This can be used to override the standard behavior of the button and 1257fb73f79340375013225618a5d87f46b958f698efMike Lockwood * keyboard backlights. A value of less than 0, the default, means to 1258fb73f79340375013225618a5d87f46b958f698efMike Lockwood * use the standard backlight behavior. 0 to 1 adjusts the brightness 1259fb73f79340375013225618a5d87f46b958f698efMike Lockwood * from dark to full bright. 1260fb73f79340375013225618a5d87f46b958f698efMike Lockwood */ 1261fb73f79340375013225618a5d87f46b958f698efMike Lockwood public float buttonBrightness = BRIGHTNESS_OVERRIDE_NONE; 1262fb73f79340375013225618a5d87f46b958f698efMike Lockwood 1263fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** 12643c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * Value for {@link #rotationAnimation} to define the animation used to 12653c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * specify that this window will rotate in or out following a rotation. 12663c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 12673c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_ROTATE = 0; 12683c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 12693c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 12703c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * Value for {@link #rotationAnimation} to define the animation used to 12713c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * specify that this window will fade in or out following a rotation. 12723c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 12733c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_CROSSFADE = 1; 12743c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 12753c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 12763c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * Value for {@link #rotationAnimation} to define the animation used to 12773c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * specify that this window will immediately disappear or appear following 12783c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * a rotation. 12793c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 12803c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_JUMPCUT = 2; 12813c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 12823c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 1283bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * Define the exit and entry animations used on this window when the device is rotated. 1284bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * This only has an affect if the incoming and outgoing topmost 12853c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * opaque windows have the #FLAG_FULLSCREEN bit set and are not covered 1286bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * by other windows. All other situations default to the 1287bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * {@link #ROTATION_ANIMATION_ROTATE} behavior. 12883c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * 12893c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * @see #ROTATION_ANIMATION_ROTATE 12903c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * @see #ROTATION_ANIMATION_CROSSFADE 12913c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * @see #ROTATION_ANIMATION_JUMPCUT 12923c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 12933c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public int rotationAnimation = ROTATION_ANIMATION_ROTATE; 12943c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 12953c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 12969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Identifier for this window. This will usually be filled in for 12979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you. 12989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public IBinder token = null; 13009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 13029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Name of the package owning this window. 13039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 13049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String packageName = null; 13059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 13079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Specific orientation value for a window. 13089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * May be any of the same values allowed 13099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * for {@link android.content.pm.ActivityInfo#screenOrientation}. 13109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * If not set, a default value of 13119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.content.pm.ActivityInfo#SCREEN_ORIENTATION_UNSPECIFIED} 13129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be used. 13139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 13149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int screenOrientation = ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED; 1315664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1316664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** 1317664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * Control the visibility of the status bar. 131814782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * 131914782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @see View#STATUS_BAR_VISIBLE 132014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @see View#STATUS_BAR_HIDDEN 1321664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato */ 1322664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public int systemUiVisibility; 1323664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1324664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** 132514782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @hide 132614782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * The ui visibility as requested by the views in this hierarchy. 132714782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * the combined value should be systemUiVisibility | subtreeSystemUiVisibility. 132814782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato */ 132914782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato public int subtreeSystemUiVisibility; 133014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato 133114782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato /** 1332664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * Get callbacks about the system ui visibility changing. 1333664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * 1334664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * TODO: Maybe there should be a bitfield of optional callbacks that we need. 1335664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * 1336664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * @hide 1337664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato */ 1338664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public boolean hasSystemUiListeners; 1339664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1340474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** 1341474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * When this window has focus, disable touch pad pointer gesture processing. 1342474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * The window will receive raw position updates from the touch pad instead 1343474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * of pointer movements and synthetic touch events. 1344474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * 1345474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @hide 1346474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown */ 1347474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public static final int INPUT_FEATURE_DISABLE_POINTER_GESTURES = 0x00000001; 1348474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 1349474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** 1350cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * Does not construct an input channel for this window. The channel will therefore 1351cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * be incapable of receiving input. 1352cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * 1353cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * @hide 1354cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown */ 1355cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown public static final int INPUT_FEATURE_NO_INPUT_CHANNEL = 0x00000002; 1356cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown 1357cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown /** 13581e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * When this window has focus, does not call user activity for all input events so 13591e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * the application will have to do it itself. Should only be used by 13601e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * the keyguard and phone app. 13611e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * <p> 13621e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Should only be used by the keyguard and phone app. 13631e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p> 13641e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * 13651e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @hide 13661e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown */ 13671e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public static final int INPUT_FEATURE_DISABLE_USER_ACTIVITY = 0x00000004; 13681e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 13691e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** 1370474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * Control special features of the input subsystem. 1371474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * 1372bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * @see #INPUT_FEATURE_DISABLE_POINTER_GESTURES 1373cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * @see #INPUT_FEATURE_NO_INPUT_CHANNEL 13741e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @see #INPUT_FEATURE_DISABLE_USER_ACTIVITY 1375474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @hide 1376474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown */ 1377474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public int inputFeatures; 1378474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 13791e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** 13801e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Sets the number of milliseconds before the user activity timeout occurs 13811e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * when this window has focus. A value of -1 uses the standard timeout. 13821e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * A value of 0 uses the minimum support display timeout. 13831e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * <p> 13841e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * This property can only be used to reduce the user specified display timeout; 13851e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * it can never make the timeout longer than it normally would be. 13861e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p><p> 13871e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Should only be used by the keyguard and phone app. 13881e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p> 13891e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * 13901e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @hide 13911e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown */ 13921e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public long userActivityTimeout = -1; 13931e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 13949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams() { 1395980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 13969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = TYPE_APPLICATION; 13979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 13989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type) { 1401980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 14049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type, int _flags) { 1407980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 14119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type, int _flags, int _format) { 1414980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 14189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int w, int h, int _type, int _flags, int _format) { 14219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(w, h); 14229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 14259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int w, int h, int xpos, int ypos, int _type, 14289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int _flags, int _format) { 14299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(w, h); 14309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = xpos; 14319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = ypos; 14329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 14359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final void setTitle(CharSequence title) { 14389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (null == title) 14399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project title = ""; 14409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = TextUtils.stringOrSpannedString(title); 14429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final CharSequence getTitle() { 14459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mTitle; 14469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int describeContents() { 14499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return 0; 14509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void writeToParcel(Parcel out, int parcelableFlags) { 14539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(width); 14549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(height); 14559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(x); 14569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(y); 14579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(type); 14589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(flags); 14595d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn out.writeInt(privateFlags); 14609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(softInputMode); 14619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(gravity); 14629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(horizontalMargin); 14639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(verticalMargin); 14649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(format); 14659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(windowAnimations); 14669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(alpha); 14679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(dimAmount); 14689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(screenBrightness); 1469fb73f79340375013225618a5d87f46b958f698efMike Lockwood out.writeFloat(buttonBrightness); 14703c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner out.writeInt(rotationAnimation); 14719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeStrongBinder(token); 14729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeString(packageName); 14739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project TextUtils.writeToParcel(mTitle, out, parcelableFlags); 14749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(screenOrientation); 1475664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato out.writeInt(systemUiVisibility); 147614782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato out.writeInt(subtreeSystemUiVisibility); 1477664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato out.writeInt(hasSystemUiListeners ? 1 : 0); 1478474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown out.writeInt(inputFeatures); 14791e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown out.writeLong(userActivityTimeout); 14809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final Parcelable.Creator<LayoutParams> CREATOR 14839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project = new Parcelable.Creator<LayoutParams>() { 14849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams createFromParcel(Parcel in) { 14859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return new LayoutParams(in); 14869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams[] newArray(int size) { 14899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return new LayoutParams[size]; 14909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }; 14929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(Parcel in) { 14959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project width = in.readInt(); 14969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project height = in.readInt(); 14979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = in.readInt(); 14989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = in.readInt(); 14999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = in.readInt(); 15009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = in.readInt(); 15015d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn privateFlags = in.readInt(); 15029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project softInputMode = in.readInt(); 15039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project gravity = in.readInt(); 15049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalMargin = in.readFloat(); 15059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalMargin = in.readFloat(); 15069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = in.readInt(); 15079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project windowAnimations = in.readInt(); 15089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project alpha = in.readFloat(); 15099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dimAmount = in.readFloat(); 15109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenBrightness = in.readFloat(); 1511fb73f79340375013225618a5d87f46b958f698efMike Lockwood buttonBrightness = in.readFloat(); 15123c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner rotationAnimation = in.readInt(); 15139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project token = in.readStrongBinder(); 15149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project packageName = in.readString(); 15159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = TextUtils.CHAR_SEQUENCE_CREATOR.createFromParcel(in); 15169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenOrientation = in.readInt(); 1517664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato systemUiVisibility = in.readInt(); 151814782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato subtreeSystemUiVisibility = in.readInt(); 1519664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato hasSystemUiListeners = in.readInt() != 0; 1520474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown inputFeatures = in.readInt(); 15211e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown userActivityTimeout = in.readLong(); 15229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15247299807d1895ea25cbe45d32b6edfd9a5723ee7aRomain Guy @SuppressWarnings({"PointlessBitwiseExpression"}) 15259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAYOUT_CHANGED = 1<<0; 15269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_CHANGED = 1<<1; 15279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAGS_CHANGED = 1<<2; 15289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FORMAT_CHANGED = 1<<3; 15299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ANIMATION_CHANGED = 1<<4; 15309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int DIM_AMOUNT_CHANGED = 1<<5; 15319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TITLE_CHANGED = 1<<6; 15329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ALPHA_CHANGED = 1<<7; 15339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_CHANGED = 1<<8; 15349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MODE_CHANGED = 1<<9; 15359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SCREEN_ORIENTATION_CHANGED = 1<<10; 15369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SCREEN_BRIGHTNESS_CHANGED = 1<<11; 15373c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_CHANGED = 1<<12; 1538fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** {@hide} */ 15393c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int BUTTON_BRIGHTNESS_CHANGED = 1<<13; 1540664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** {@hide} */ 15413c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int SYSTEM_UI_VISIBILITY_CHANGED = 1<<14; 1542664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** {@hide} */ 15433c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int SYSTEM_UI_LISTENER_CHANGED = 1<<15; 1544474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** {@hide} */ 15453c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int INPUT_FEATURES_CHANGED = 1<<16; 15465d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** {@hide} */ 15473c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int PRIVATE_FLAGS_CHANGED = 1<<17; 1548f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy /** {@hide} */ 15493c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int USER_ACTIVITY_TIMEOUT_CHANGED = 1<<18; 15501e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** {@hide} */ 1551f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy public static final int EVERYTHING_CHANGED = 0xffffffff; 1552f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy 1553e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima // internal buffer to backup/restore parameters under compatibility mode. 1554e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima private int[] mCompatibilityParamsBackup = null; 1555e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima 15569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final int copyFrom(LayoutParams o) { 15579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int changes = 0; 15589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (width != o.width) { 15609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project width = o.width; 156140e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 15629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (height != o.height) { 15649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project height = o.height; 156540e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 15669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (x != o.x) { 15689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = o.x; 15699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= LAYOUT_CHANGED; 15709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (y != o.y) { 15729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = o.y; 15739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= LAYOUT_CHANGED; 15749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (horizontalWeight != o.horizontalWeight) { 15769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalWeight = o.horizontalWeight; 157740e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 15789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (verticalWeight != o.verticalWeight) { 15809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalWeight = o.verticalWeight; 158140e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 15829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (horizontalMargin != o.horizontalMargin) { 15849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalMargin = o.horizontalMargin; 158540e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 15869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (verticalMargin != o.verticalMargin) { 15889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalMargin = o.verticalMargin; 158940e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 15909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (type != o.type) { 15929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = o.type; 15939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= TYPE_CHANGED; 15949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (flags != o.flags) { 15969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = o.flags; 159740e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= FLAGS_CHANGED; 15989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15995d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn if (privateFlags != o.privateFlags) { 16005d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn privateFlags = o.privateFlags; 16015d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn changes |= PRIVATE_FLAGS_CHANGED; 16025d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn } 16039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (softInputMode != o.softInputMode) { 16049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project softInputMode = o.softInputMode; 16059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= SOFT_INPUT_MODE_CHANGED; 16069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (gravity != o.gravity) { 16089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project gravity = o.gravity; 160940e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (format != o.format) { 16129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = o.format; 161340e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= FORMAT_CHANGED; 16149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (windowAnimations != o.windowAnimations) { 16169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project windowAnimations = o.windowAnimations; 16179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= ANIMATION_CHANGED; 16189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (token == null) { 16209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // NOTE: token only copied if the recipient doesn't 16219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // already have one. 16229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project token = o.token; 16239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (packageName == null) { 16259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // NOTE: packageName only copied if the recipient doesn't 16269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // already have one. 16279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project packageName = o.packageName; 16289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mTitle.equals(o.mTitle)) { 16309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = o.mTitle; 16319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= TITLE_CHANGED; 16329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (alpha != o.alpha) { 16349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project alpha = o.alpha; 16359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= ALPHA_CHANGED; 16369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (dimAmount != o.dimAmount) { 16389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dimAmount = o.dimAmount; 16399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= DIM_AMOUNT_CHANGED; 16409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenBrightness != o.screenBrightness) { 16429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenBrightness = o.screenBrightness; 16439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= SCREEN_BRIGHTNESS_CHANGED; 16449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1645fb73f79340375013225618a5d87f46b958f698efMike Lockwood if (buttonBrightness != o.buttonBrightness) { 1646fb73f79340375013225618a5d87f46b958f698efMike Lockwood buttonBrightness = o.buttonBrightness; 1647fb73f79340375013225618a5d87f46b958f698efMike Lockwood changes |= BUTTON_BRIGHTNESS_CHANGED; 1648fb73f79340375013225618a5d87f46b958f698efMike Lockwood } 16493c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner if (rotationAnimation != o.rotationAnimation) { 16503c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner rotationAnimation = o.rotationAnimation; 16513c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner changes |= ROTATION_ANIMATION_CHANGED; 16523c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner } 16539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 16549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenOrientation != o.screenOrientation) { 16559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenOrientation = o.screenOrientation; 165640e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= SCREEN_ORIENTATION_CHANGED; 16579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1658529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy 165914782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato if (systemUiVisibility != o.systemUiVisibility 166014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato || subtreeSystemUiVisibility != o.subtreeSystemUiVisibility) { 1661664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato systemUiVisibility = o.systemUiVisibility; 166214782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato subtreeSystemUiVisibility = o.subtreeSystemUiVisibility; 1663664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato changes |= SYSTEM_UI_VISIBILITY_CHANGED; 1664664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1665664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1666664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (hasSystemUiListeners != o.hasSystemUiListeners) { 1667664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato hasSystemUiListeners = o.hasSystemUiListeners; 1668664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato changes |= SYSTEM_UI_LISTENER_CHANGED; 1669664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1670664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1671474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown if (inputFeatures != o.inputFeatures) { 1672474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown inputFeatures = o.inputFeatures; 1673474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown changes |= INPUT_FEATURES_CHANGED; 1674474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown } 1675474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 16761e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown if (userActivityTimeout != o.userActivityTimeout) { 16771e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown userActivityTimeout = o.userActivityTimeout; 16781e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown changes |= USER_ACTIVITY_TIMEOUT_CHANGED; 16791e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown } 16801e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 16819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return changes; 16829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 16849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 16859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String debug(String output) { 16869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project output += "Contents of " + this + ":"; 16879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", output); 16889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project output = super.debug(""); 16899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", output); 16909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", ""); 16919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", "WindowManager.LayoutParams={title=" + mTitle + "}"); 16929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return ""; 16939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 16959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 16969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String toString() { 16979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project StringBuilder sb = new StringBuilder(256); 16989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append("WM.LayoutParams{"); 16999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append("("); 17009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(x); 17019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(','); 17029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(y); 17039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(")("); 1704980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy sb.append((width== MATCH_PARENT ?"fill":(width==WRAP_CONTENT?"wrap":width))); 17059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append('x'); 1706980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy sb.append((height== MATCH_PARENT ?"fill":(height==WRAP_CONTENT?"wrap":height))); 17079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(")"); 17088eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (horizontalMargin != 0) { 17098eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" hm="); 17108eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(horizontalMargin); 17118eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 17128eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (verticalMargin != 0) { 17138eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" vm="); 17148eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(verticalMargin); 17159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (gravity != 0) { 17179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" gr=#"); 17189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(gravity)); 17199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17208eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (softInputMode != 0) { 17218eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" sim=#"); 17228eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(Integer.toHexString(softInputMode)); 17238eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 17249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" ty="); 17259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(type); 17269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" fl=#"); 17279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(flags)); 17285d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn if (privateFlags != 0) { 17295d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn sb.append(" pfl=0x").append(Integer.toHexString(privateFlags)); 17305d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn } 1731a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn if (format != PixelFormat.OPAQUE) { 1732a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(" fmt="); 1733a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(format); 1734a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn } 17359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (windowAnimations != 0) { 17369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" wanim=0x"); 17379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(windowAnimations)); 17389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenOrientation != ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED) { 17409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" or="); 17419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(screenOrientation); 17429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17438eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (alpha != 1.0f) { 17448eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" alpha="); 17458eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(alpha); 17468eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 17478eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (screenBrightness != BRIGHTNESS_OVERRIDE_NONE) { 17488eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" sbrt="); 17498eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(screenBrightness); 17508eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 17518eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (buttonBrightness != BRIGHTNESS_OVERRIDE_NONE) { 17528eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" bbrt="); 17538eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(buttonBrightness); 17548eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 17553c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner if (rotationAnimation != ROTATION_ANIMATION_ROTATE) { 17563c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner sb.append(" rotAnim="); 17573c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner sb.append(rotationAnimation); 17583c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner } 17595a2b91dc14e4c92e91c6abcc795f54ac98ee5866Mitsuru Oshima if ((flags & FLAG_COMPATIBLE_WINDOW) != 0) { 17605a2b91dc14e4c92e91c6abcc795f54ac98ee5866Mitsuru Oshima sb.append(" compatible=true"); 17615a2b91dc14e4c92e91c6abcc795f54ac98ee5866Mitsuru Oshima } 1762664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (systemUiVisibility != 0) { 1763664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(" sysui=0x"); 1764664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(Integer.toHexString(systemUiVisibility)); 1765664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 176614782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato if (subtreeSystemUiVisibility != 0) { 176714782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato sb.append(" vsysui=0x"); 176814782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato sb.append(Integer.toHexString(subtreeSystemUiVisibility)); 176914782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato } 1770664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (hasSystemUiListeners) { 1771664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(" sysuil="); 1772664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(hasSystemUiListeners); 1773664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1774a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn if (inputFeatures != 0) { 1775a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(" if=0x").append(Integer.toHexString(inputFeatures)); 1776a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn } 17771e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown if (userActivityTimeout >= 0) { 17781e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown sb.append(" userActivityTimeout=").append(userActivityTimeout); 17791e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown } 17809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append('}'); 17819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return sb.toString(); 17829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17838d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima 17843d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima /** 17853d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima * Scale the layout params' coordinates and size. 178664f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima * @hide 1787e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 178864f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima public void scale(float scale) { 178961324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima x = (int) (x * scale + 0.5f); 179061324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima y = (int) (y * scale + 0.5f); 1791e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (width > 0) { 179261324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima width = (int) (width * scale + 0.5f); 1793e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima } 1794e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (height > 0) { 179561324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima height = (int) (height * scale + 0.5f); 17968d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima } 17978d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima } 17988d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima 17993d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima /** 1800e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * Backup the layout parameters used in compatibility mode. 1801e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * @see LayoutParams#restore() 1802e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 1803e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima void backup() { 1804e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima int[] backup = mCompatibilityParamsBackup; 1805e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (backup == null) { 180664f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima // we backup 4 elements, x, y, width, height 180764f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima backup = mCompatibilityParamsBackup = new int[4]; 18083d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 1809e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[0] = x; 1810e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[1] = y; 1811e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[2] = width; 1812e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[3] = height; 1813e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima } 1814e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima 1815e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima /** 1816e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * Restore the layout params' coordinates, size and gravity 1817e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * @see LayoutParams#backup() 1818e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 1819e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima void restore() { 1820e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima int[] backup = mCompatibilityParamsBackup; 1821e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (backup != null) { 1822e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima x = backup[0]; 1823e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima y = backup[1]; 1824e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima width = backup[2]; 18253d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima height = backup[3]; 18263d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 18273d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 18283d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima 18299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private CharSequence mTitle = ""; 18309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 18319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1832