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"), 222a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung @ViewDebug.IntToString(from = TYPE_MAGNIFICATION_OVERLAY, to = "TYPE_MAGNIFICATION_OVERLAY"), 223e3d2cc8fcc4ab3df195071acf2f8709c148656f8keunyoung @ViewDebug.IntToString(from = TYPE_PRIVATE_PRESENTATION, to = "TYPE_PRIVATE_PRESENTATION") 2248f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato }) 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int type; 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of window types that represent normal application windows. 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_APPLICATION_WINDOW = 1; 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: an application window that serves as the "base" window 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the overall application; all other application windows will 2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * appear on top of it. 2365962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows only on the owning user's window. 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_BASE_APPLICATION = 1; 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a normal application window. The {@link #token} must be 2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an Activity token identifying who the window belongs to. 2435962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows only on the owning user's window. 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION = 2; 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: special application window that is displayed while the 2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application is starting. Not for use by applications themselves; 2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this is used by the system to display something until the 2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application can show its own windows. 2525962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows on all users' windows. 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_STARTING = 3; 2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of application windows. 2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_APPLICATION_WINDOW = 99; 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of types of sub-windows. The {@link #token} of these windows 2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * must be set to the window they are attached to. These types of 2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are kept next to their attached window in Z-order, and their 2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * coordinate space is relative to their attached window. 2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_SUB_WINDOW = 1000; 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a panel on top of an application window. These windows 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * appear on top of their attached window. 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_PANEL = FIRST_SUB_WINDOW; 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 27633291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * Window type: window for showing media (such as video). These windows 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are displayed behind their attached window. 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_MEDIA = FIRST_SUB_WINDOW+1; 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a sub-panel on top of an application window. These 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are displayed on top their attached window and any 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #TYPE_APPLICATION_PANEL} panels. 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_SUB_PANEL = FIRST_SUB_WINDOW+2; 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window type: like {@link #TYPE_APPLICATION_PANEL}, but layout 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the window happens as that of a top-level window, <em>not</em> 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * as a child of its container. 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_ATTACHED_DIALOG = FIRST_SUB_WINDOW+3; 2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 295c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * Window type: window for showing overlays on top of media windows. 296c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * These windows are displayed between TYPE_APPLICATION_MEDIA and the 297c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * application window. They should be translucent to be useful. This 298c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * is a big ugly hack so: 299c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * @hide 300c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn */ 301c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn public static final int TYPE_APPLICATION_MEDIA_OVERLAY = FIRST_SUB_WINDOW+4; 302c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn 303c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn /** 3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of sub-windows. 3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_SUB_WINDOW = 1999; 3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of system-specific window types. These are not normally 3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * created by applications. 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_SYSTEM_WINDOW = 2000; 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: the status bar. There can be only one status bar 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window; it is placed at the top of the screen, and all other 3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are shifted down so they are below it. 31888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_STATUS_BAR = FIRST_SYSTEM_WINDOW; 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: the search bar. There can be only one search bar 3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window; it is placed at the top of the screen. 32588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SEARCH_BAR = FIRST_SYSTEM_WINDOW+1; 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: phone. These are non-application windows providing 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user interaction with the phone (in particular incoming calls). 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * These windows are normally placed above all applications, but behind 3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the status bar. 33488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_PHONE = FIRST_SYSTEM_WINDOW+2; 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: system window, such as low power alert. These windows 3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are always on top of application windows. 34188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_ALERT = FIRST_SYSTEM_WINDOW+3; 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: keyguard window. 34788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_KEYGUARD = FIRST_SYSTEM_WINDOW+4; 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: transient notifications. 35388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_TOAST = FIRST_SYSTEM_WINDOW+5; 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: system overlay windows, which need to be displayed 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * on top of everything else. These windows must not take input 3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus, or they will interfere with the keyguard. 36188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_OVERLAY = FIRST_SYSTEM_WINDOW+6; 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: priority phone UI, which needs to be displayed even if 3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the keyguard is active. These windows must not take input 3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus, or they will interfere with the keyguard. 36988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_PRIORITY_PHONE = FIRST_SYSTEM_WINDOW+7; 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: panel that slides out from the status bar 37588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_DIALOG = FIRST_SYSTEM_WINDOW+8; 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: dialogs that the keyguard shows 38188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_KEYGUARD_DIALOG = FIRST_SYSTEM_WINDOW+9; 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal system error windows, appear on top of 3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * everything they can. 38888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_ERROR = FIRST_SYSTEM_WINDOW+10; 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal input methods windows, which appear above 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the normal UI. Application windows may be resized or panned to keep 3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the input focus visible while this window is displayed. 39688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_INPUT_METHOD = FIRST_SYSTEM_WINDOW+11; 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal input methods dialog windows, which appear above 4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the current input method window. 40388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_INPUT_METHOD_DIALOG= FIRST_SYSTEM_WINDOW+12; 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4084c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * Window type: wallpaper window, placed behind any window that wants 4094c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * to sit on top of the wallpaper. 41088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4114c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 4124c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int TYPE_WALLPAPER = FIRST_SYSTEM_WINDOW+13; 4134c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn 4144c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn /** 41529fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato * Window type: panel that slides out from over the status bar 41688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 417badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn */ 418badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn public static final int TYPE_STATUS_BAR_PANEL = FIRST_SYSTEM_WINDOW+14; 4193b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown 4203b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown /** 4213b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * Window type: secure system overlay windows, which need to be displayed 4223b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * on top of everything else. These windows must not take input 4233b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * focus, or they will interfere with the keyguard. 4243b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * 4253b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * This is exactly like {@link #TYPE_SYSTEM_OVERLAY} except that only the 4263b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * system itself is allowed to create these overlays. Applications cannot 4273b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * obtain permission to create secure system overlays. 42888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * 42988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4303b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * @hide 4313b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown */ 4323b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown public static final int TYPE_SECURE_SYSTEM_OVERLAY = FIRST_SYSTEM_WINDOW+15; 4333b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown 434badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn /** 435a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * Window type: the drag-and-drop pseudowindow. There is only one 436a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * drag layer (at most), and it is placed on top of all other windows. 43788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 438a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * @hide 439a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate */ 4403b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown public static final int TYPE_DRAG = FIRST_SYSTEM_WINDOW+16; 441a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate 442a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate /** 44329fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato * Window type: panel that slides out from under the status bar 44488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 445a89e903fd4b84778e1a7f2268fe025fe66a6e45eJoe Onorato * @hide 44629fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato */ 44729fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato public static final int TYPE_STATUS_BAR_SUB_PANEL = FIRST_SYSTEM_WINDOW+17; 44829fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato 44983c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown /** 45083c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown * Window type: (mouse) pointer 45188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 45283c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown * @hide 45383c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown */ 45483c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown public static final int TYPE_POINTER = FIRST_SYSTEM_WINDOW+18; 45529fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato 45629fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato /** 4578956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler * Window type: Navigation bar (when distinct from status bar) 45888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 4598956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler * @hide 4608956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler */ 4618956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler public static final int TYPE_NAVIGATION_BAR = FIRST_SYSTEM_WINDOW+19; 4628956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler 4638956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler /** 464e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * Window type: The volume level overlay/dialog shown when the user 465e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * changes the system volume. 46688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 467e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * @hide 468e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn */ 469e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn public static final int TYPE_VOLUME_OVERLAY = FIRST_SYSTEM_WINDOW+20; 470e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn 471e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn /** 47229aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * Window type: The boot progress dialog, goes on top of everything 47329aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * in the world. 47488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 47529aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * @hide 47629aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn */ 47729aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn public static final int TYPE_BOOT_PROGRESS = FIRST_SYSTEM_WINDOW+21; 47829aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn 47929aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn /** 480df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * Window type: Fake window to consume touch events when the navigation 481df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * bar is hidden. 48288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 483df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * @hide 484df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn */ 485df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn public static final int TYPE_HIDDEN_NAV_CONSUMER = FIRST_SYSTEM_WINDOW+22; 486df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn 487df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn /** 4887d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler * Window type: Dreams (screen saver) window, just above keyguard. 48988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4907d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler * @hide 4917d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler */ 4927d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler public static final int TYPE_DREAM = FIRST_SYSTEM_WINDOW+23; 4937d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler 4947d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler /** 495e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller * Window type: Navigation bar panel (when navigation bar is distinct from status bar) 49688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 497e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller * @hide 498e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller */ 499e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller public static final int TYPE_NAVIGATION_BAR_PANEL = FIRST_SYSTEM_WINDOW+24; 500e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller 501e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller /** 502a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn * Window type: Behind the universe of the real windows. 50388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 504a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn * @hide 505a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn */ 506a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn public static final int TYPE_UNIVERSE_BACKGROUND = FIRST_SYSTEM_WINDOW+25; 507a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn 508a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn /** 509bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown * Window type: Display overlay window. Used to simulate secondary display devices. 51088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 511bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown * @hide 512bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown */ 513bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown public static final int TYPE_DISPLAY_OVERLAY = FIRST_SYSTEM_WINDOW+26; 514bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown 515bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown /** 5161cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * Window type: Magnification overlay window. Used to highlight the magnified 5171cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * portion of a display when accessibility magnification is enabled. 51888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 5191cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * @hide 5201cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov */ 5211cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov public static final int TYPE_MAGNIFICATION_OVERLAY = FIRST_SYSTEM_WINDOW+27; 5221cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov 5231cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov /** 52488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * Window type: Recents. Same layer as {@link #TYPE_SYSTEM_DIALOG} but only appears on 52588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * one user's screen. 52688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 52788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * @hide 52888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner */ 52988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner public static final int TYPE_RECENTS_OVERLAY = FIRST_SYSTEM_WINDOW+28; 53088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner 5315ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller 5325ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller /** 5335ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller * Window type: keyguard scrim window. Shows if keyguard needs to be restarted. 5345ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller * In multiuser systems shows on all users' windows. 5355ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller * @hide 5365ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller */ 5375ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller public static final int TYPE_KEYGUARD_SCRIM = FIRST_SYSTEM_WINDOW+29; 5385ecd81154fa039961f65bb4e36d18ac555b0d1d6Jim Miller 53988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner /** 540a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung * Window type: Window for Presentation on top of private 541a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung * virtual display. 542a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung */ 543a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung public static final int TYPE_PRIVATE_PRESENTATION = FIRST_SYSTEM_WINDOW+30; 544a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung 545a446bf0e8c7b5f5441aeb11b359ba6776b9b3061keunyoung /** 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of system windows. 5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_SYSTEM_WINDOW = 2999; 5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 550d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 551d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian @Deprecated 5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_NORMAL = 0; 553d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 554317a6280cc109e873646e4652be1582d870eedfdMathias Agopian @Deprecated 5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_HARDWARE = 1; 556d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 557317a6280cc109e873646e4652be1582d870eedfdMathias Agopian @Deprecated 5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_GPU = 2; 559d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 560d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian @Deprecated 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_PUSH_BUFFERS = 3; 5625d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5645d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @deprecated this is ignored 5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5665d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @Deprecated 5675d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int memoryType; 5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 569ef73162887943e16587b8e737b19e59348338e8cMike Lockwood /** Window flag: as long as this window is visible to the user, allow 570ef73162887943e16587b8e737b19e59348338e8cMike Lockwood * the lock screen to activate while the screen is on. 571ef73162887943e16587b8e737b19e59348338e8cMike Lockwood * This can be used independently, or in combination with 57295f7850a9d9c7c4f020d06986300f4740fb6a52cChristopher Tate * {@link #FLAG_KEEP_SCREEN_ON} and/or {@link #FLAG_SHOW_WHEN_LOCKED} */ 573ef73162887943e16587b8e737b19e59348338e8cMike Lockwood public static final int FLAG_ALLOW_LOCK_WHILE_SCREEN_ON = 0x00000001; 574ef73162887943e16587b8e737b19e59348338e8cMike Lockwood 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: everything behind this window will be dimmed. 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Use {@link #dimAmount} to control the amount of dim. */ 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_DIM_BEHIND = 0x00000002; 5785d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5795d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** Window flag: blur everything behind this window. 5805d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @deprecated Blurring is no longer supported. */ 5815d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @Deprecated 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_BLUR_BEHIND = 0x00000004; 5835d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: this window won't ever get key input focus, so the 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user can not send key or other button events to it. Those will 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * instead go to whatever focusable window is behind it. This flag 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will also enable {@link #FLAG_NOT_TOUCH_MODAL} whether or not that 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is explicitly set. 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>Setting this flag also implies that the window will not need to 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * interact with 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * a soft input method, so it will be Z-ordered and positioned 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * independently of any active input method (typically this means it 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * gets Z-ordered on top of the input method, so it can use the full 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen for its content and cover the input method if needed. You 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can use {@link #FLAG_ALT_FOCUSABLE_IM} to modify this behavior. */ 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_FOCUSABLE = 0x00000008; 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: this window can never receive touch events. */ 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_TOUCHABLE = 0x00000010; 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 60233291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: even when this window is focusable (its 60333291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * {@link #FLAG_NOT_FOCUSABLE} is not set), allow any pointer events 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * outside of the window to be sent to the windows behind it. Otherwise 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * it will consume all pointer events itself, regardless of whether they 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are inside of the window. */ 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_TOUCH_MODAL = 0x00000020; 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 60933291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: when set, if the device is asleep when the touch 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen is pressed, you will receive this first touch event. Usually 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the first touch event is consumed by the system since the user can 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not see what they are pressing on. 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_TOUCHABLE_WHEN_WAKING = 0x00000040; 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: as long as this window is visible to the user, keep 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the device's screen turned on and bright. */ 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_KEEP_SCREEN_ON = 0x00000080; 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: place the window within the entire screen, ignoring 62133291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * decorations around the border (such as the status bar). The 6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window must correctly position its contents to take the screen 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * decoration into account. This flag is normally set for you 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * by Window as described in {@link Window#setFlags}. */ 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_IN_SCREEN = 0x00000100; 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: allow window to extend outside of the screen. */ 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_NO_LIMITS = 0x00000200; 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6301bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn /** 63133291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * Window flag: hide all screen decorations (such as the status bar) while 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this window is displayed. This allows the window to use the entire 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * display space for itself -- the status bar will be hidden when 63445c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * an app window with this flag set is on the top layer. A fullscreen window 63545c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * will ignore a value of {@link #SOFT_INPUT_ADJUST_RESIZE} for the window's 63645c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * {@link #softInputMode} field; the window will stay fullscreen 63745c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * and will not resize. 6381bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 6391bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 6401bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowFullscreen} attribute; this attribute 6411bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * is automatically set for you in the standard fullscreen themes 6421bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * such as {@link android.R.style#Theme_NoTitleBar_Fullscreen}, 6431bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Black_NoTitleBar_Fullscreen}, 6441bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Light_NoTitleBar_Fullscreen}, 6451bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_NoActionBar_Fullscreen}, 6461bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Light_NoActionBar_Fullscreen}, 6471bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_NoActionBar_Fullscreen}, and 6481bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Light_NoActionBar_Fullscreen}.</p> 6491bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn */ 6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_FULLSCREEN = 0x00000400; 6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 65233291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: override {@link #FLAG_FULLSCREEN} and force the 65333291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock * screen decorations (such as the status bar) to be shown. */ 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_FORCE_NOT_FULLSCREEN = 0x00000800; 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: turn on dithering when compositing this window to 6573cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown * the screen. 6583cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown * @deprecated This flag is no longer used. */ 6593cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown @Deprecated 6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_DITHER = 0x00001000; 6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 66233291d8d71278a2f0770018c977ff2626f71e2dcJohn Spurlock /** Window flag: treat the content of the window as secure, preventing 663f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * it from appearing in screenshots or from being viewed on non-secure 664f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * displays. 665f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * 666f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * <p>See {@link android.view.Display#FLAG_SECURE} for more details about 667f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * secure surfaces and secure displays. 668f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown */ 6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SECURE = 0x00002000; 6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special mode where the layout parameters are used 6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to perform scaling of the surface when it is composited to the 6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen. */ 6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SCALED = 0x00004000; 6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: intended for windows that will often be used when the user is 6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * holding the screen against their face, it will aggressively filter the event 6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * stream to prevent unintended presses in this situation that may not be 6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * desired for a particular window, when such an event stream is detected, the 6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application will receive a CANCEL motion event to indicate this so applications 6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can handle this accordingly by taking no action on the event 6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * until the finger is released. */ 6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_IGNORE_CHEEK_PRESSES = 0x00008000; 6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special option only for use in combination with 6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_LAYOUT_IN_SCREEN}. When requesting layout in the 6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen your window may appear on top of or behind screen decorations 6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * such as the status bar. By also including this flag, the window 6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * manager will report the inset rectangle needed to ensure your 6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * content is not covered by screen decorations. This flag is normally 6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set for you by Window as described in {@link Window#setFlags}.*/ 6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_INSET_DECOR = 0x00010000; 6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: invert the state of {@link #FLAG_NOT_FOCUSABLE} with 6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * respect to how this window interacts with the current method. That 6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is, if FLAG_NOT_FOCUSABLE is set and this flag is set, then the 6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window will behave as if it needs to interact with the input method 6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and thus be placed behind/away from it; if FLAG_NOT_FOCUSABLE is 6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not set and this flag is set, then the window will behave as if it 7009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * doesn't need to interact with the input method and can be placed 7019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to use more space and cover the input method. 7029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_ALT_FOCUSABLE_IM = 0x00020000; 7049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: if you have set {@link #FLAG_NOT_TOUCH_MODAL}, you 7069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can set this flag to receive a single special MotionEvent with 7079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the action 7089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link MotionEvent#ACTION_OUTSIDE MotionEvent.ACTION_OUTSIDE} for 7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * touches that occur outside of your window. Note that you will not 7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * receive the full down/move/up gesture, only the location of the 7119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * first down as an ACTION_OUTSIDE. 7129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_WATCH_OUTSIDE_TOUCH = 0x00040000; 7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 715d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu /** Window flag: special flag to let windows be shown when the screen 716d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * is locked. This will let application windows take precedence over 717d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * key guard or any other lock screens. Can be used with 718d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * {@link #FLAG_KEEP_SCREEN_ON} to turn screen on and display windows 7199bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * directly before showing the key guard window. Can be used with 7209bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * {@link #FLAG_DISMISS_KEYGUARD} to automatically fully dismisss 7219bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * non-secure keyguards. This flag only applies to the top-most 7229bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * full-screen window. 7234c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 724d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu public static final int FLAG_SHOW_WHEN_LOCKED = 0x00080000; 725d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu 7264c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn /** Window flag: ask that the system wallpaper be shown behind 7274c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * your window. The window surface must be translucent to be able 7284c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * to actually see the wallpaper behind it; this flag just ensures 7294c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * that the wallpaper surface will be there if this window actually 7304c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * has translucent regions. 7311bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 7321bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 7331bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowShowWallpaper} attribute; this attribute 7341bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * is automatically set for you in the standard wallpaper themes 7351bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * such as {@link android.R.style#Theme_Wallpaper}, 7361bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Wallpaper_NoTitleBar}, 7371bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Wallpaper_NoTitleBar_Fullscreen}, 7381bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Wallpaper}, 7391bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Wallpaper_NoTitleBar}, 7401bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Wallpaper}, and 7411bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Wallpaper_NoTitleBar}.</p> 7424c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 7434c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int FLAG_SHOW_WALLPAPER = 0x00100000; 7444c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn 74593e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn /** Window flag: when set as a window is being added or made 74693e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * visible, once the window has been shown then the system will 74793e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * poke the power manager's user activity (as if the user had woken 74893e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * up the device) to turn the screen on. */ 74993e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn public static final int FLAG_TURN_SCREEN_ON = 0x00200000; 75093e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn 7519bfb707597898f54722460b48588007b682f3e2aDianne Hackborn /** Window flag: when set the window will cause the keyguard to 7529bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * be dismissed, only if it is not a secure lock keyguard. Because such 7539bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * a keyguard is not needed for security, it will never re-appear if 7549bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * the user navigates to another window (in contrast to 7559bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * {@link #FLAG_SHOW_WHEN_LOCKED}, which will only temporarily 7569bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * hide both secure and non-secure keyguards but ensure they reappear 7579bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * when the user moves to another UI that doesn't hide them). 7589bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * If the keyguard is currently active and is secure (requires an 7599bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * unlock pattern) than the user will still need to confirm it before 7609bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * seeing this window, unless {@link #FLAG_SHOW_WHEN_LOCKED} has 761ae069f76ee65fd5d9252c8191429fa55296d0208Daniel Sandler * also been set. 762ae069f76ee65fd5d9252c8191429fa55296d0208Daniel Sandler */ 7639bfb707597898f54722460b48588007b682f3e2aDianne Hackborn public static final int FLAG_DISMISS_KEYGUARD = 0x00400000; 76401ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown 76501ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown /** Window flag: when set the window will accept for touch events 76601ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * outside of its bounds to be sent to other windows that also 76701ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * support split touch. When this flag is not set, the first pointer 76801ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * that goes down determines the window to which all subsequent touches 76901ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * go until all pointers go up. When this flag is set, each pointer 77001ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * (not necessarily the first) that goes down determines the window 77101ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * to which all subsequent touches of that pointer will go until that 77201ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * pointer goes up thereby enabling touches with multiple pointers 77301ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * to be split across multiple windows. 774d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn */ 77501ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown public static final int FLAG_SPLIT_TOUCH = 0x00800000; 776d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn 777d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn /** 77872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>Indicates whether this window should be hardware accelerated. 77972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * Requesting hardware acceleration does not guarantee it will happen.</p> 780c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 78172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag can be controlled programmatically <em>only</em> to enable 78272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * hardware acceleration. To enable hardware acceleration for a given 78372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * window programmatically, do the following:</p> 784c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 78572f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <pre> 78672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * Window w = activity.getWindow(); // in Activity's onCreate() for instance 78772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * w.setFlags(WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED, 78872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED); 78972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * </pre> 790c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 79172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>It is important to remember that this flag <strong>must</strong> 79272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * be set before setting the content view of your activity or dialog.</p> 793c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 79472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag cannot be used to disable hardware acceleration after it 79572f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * was enabled in your manifest using 79672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * {@link android.R.attr#hardwareAccelerated}. If you need to selectively 79772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * and programmatically disable hardware acceleration (for automated testing 79872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * for instance), make sure it is turned off in your manifest and enable it 79972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * on your activity or dialog when you need it instead, using the method 80072f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * described above.</p> 801c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * 80272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag is automatically set by the system if the 80372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * {@link android.R.attr#hardwareAccelerated android:hardwareAccelerated} 80472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * XML attribute is set to true on an activity or on the application.</p> 805d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn */ 806d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn public static final int FLAG_HARDWARE_ACCELERATED = 0x01000000; 807611fae4c39edbeb23b53f789a0219c539cf32fa6Daniel Sandler 8081bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn /** 8091bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * Window flag: allow window contents to extend in to the screen's 810c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * overscan area, if there is one. The window should still correctly 811c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn * position its contents to take the overscan area into account. 8121bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8131bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 8141bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowOverscan} attribute; this attribute 8151bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * is automatically set for you in the standard overscan themes 8164e0eb22fdf56b8f3fd1bff09c4064b35b80751c1Ying Wang * such as 8171bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_NoActionBar_Overscan}, 8181bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_Holo_Light_NoActionBar_Overscan}, 8191bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_NoActionBar_Overscan}, and 8201bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.style#Theme_DeviceDefault_Light_NoActionBar_Overscan}.</p> 8211bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8221bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>When this flag is enabled for a window, its normal content may be obscured 8231bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * to some degree by the overscan region of the display. To ensure key parts of 8241bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * that content are visible to the user, you can use 8251bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link View#setFitsSystemWindows(boolean) View.setFitsSystemWindows(boolean)} 8261bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * to set the point in the view hierarchy where the appropriate offsets should 8271bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * be applied. (This can be done either by directly calling this function, using 8281bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * the {@link android.R.attr#fitsSystemWindows} attribute in your view hierarchy, 8291bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * or implementing you own {@link View#fitSystemWindows(android.graphics.Rect) 8301bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * View.fitSystemWindows(Rect)} method).</p> 8311bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8321bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This mechanism for positioning content elements is identical to its equivalent 8331bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * use with layout and {@link View#setSystemUiVisibility(int) 8341bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * View.setSystemUiVisibility(int)}; here is an example layout that will correctly 8351bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * position its UI elements with this overscan flag is set:</p> 8361bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 8371bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@sample development/samples/ApiDemos/res/layout/overscan_activity.xml complete} 838c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn */ 839c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn public static final int FLAG_LAYOUT_IN_OVERSCAN = 0x02000000; 840c652de8141f5b8e3c6bcf8916842b6e106413b1aDianne Hackborn 841bd95740648372449a4d5c164d7050eee352d4c24John Spurlock /** 842bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * Window flag: request a translucent status bar with minimal system-provided 843bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * background protection. 844bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * 845bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * <p>This flag can be controlled in your theme through the 846bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.attr#windowTranslucentStatus} attribute; this attribute 847bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * is automatically set for you in the standard translucent decor themes 848bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * such as 849bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_Holo_NoActionBar_TranslucentDecor}, 850bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_Holo_Light_NoActionBar_TranslucentDecor}, 851bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_DeviceDefault_NoActionBar_TranslucentDecor}, and 852bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_DeviceDefault_Light_NoActionBar_TranslucentDecor}.</p> 853bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * 854bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * <p>When this flag is enabled for a window, it automatically sets 855bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * the system UI visibility flags {@link View#SYSTEM_UI_FLAG_LAYOUT_STABLE} and 856bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link View#SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN}.</p> 857bd95740648372449a4d5c164d7050eee352d4c24John Spurlock */ 858bd95740648372449a4d5c164d7050eee352d4c24John Spurlock public static final int FLAG_TRANSLUCENT_STATUS = 0x04000000; 859bd95740648372449a4d5c164d7050eee352d4c24John Spurlock 860bd95740648372449a4d5c164d7050eee352d4c24John Spurlock /** 861bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * Window flag: request a translucent navigation bar with minimal system-provided 862bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * background protection. 863bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * 864bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * <p>This flag can be controlled in your theme through the 865bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.attr#windowTranslucentNavigation} attribute; this attribute 866bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * is automatically set for you in the standard translucent decor themes 867bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * such as 868bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_Holo_NoActionBar_TranslucentDecor}, 869bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_Holo_Light_NoActionBar_TranslucentDecor}, 870bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_DeviceDefault_NoActionBar_TranslucentDecor}, and 871bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link android.R.style#Theme_DeviceDefault_Light_NoActionBar_TranslucentDecor}.</p> 872bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * 873bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * <p>When this flag is enabled for a window, it automatically sets 874bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * the system UI visibility flags {@link View#SYSTEM_UI_FLAG_LAYOUT_STABLE} and 875bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@link View#SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION}.</p> 876bd95740648372449a4d5c164d7050eee352d4c24John Spurlock */ 877bd95740648372449a4d5c164d7050eee352d4c24John Spurlock public static final int FLAG_TRANSLUCENT_NAVIGATION = 0x08000000; 878bd95740648372449a4d5c164d7050eee352d4c24John Spurlock 879d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn // ----- HIDDEN FLAGS. 880d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn // These start at the high bit and go down. 88198db5fabdad86dca379740d8050697950b9f026cJeff Brown 8826a591f585909415a1da431a2cc76b7732724037dAdam Lesinski /** 8836a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * Flag for a window in local focus mode. 8846a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * Window in local focus mode can control focus independent of window manager using 8856a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * {@link Window#setLocalFocus(boolean, boolean)}. 8866a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * Usually window in this mode will not get touch/key events from window manager, but will 8876a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * get events only via local injection using {@link Window#injectInputEvent(InputEvent)}. 8886a591f585909415a1da431a2cc76b7732724037dAdam Lesinski */ 8896a591f585909415a1da431a2cc76b7732724037dAdam Lesinski public static final int FLAG_LOCAL_FOCUS_MODE = 0x10000000; 8906a591f585909415a1da431a2cc76b7732724037dAdam Lesinski 89198db5fabdad86dca379740d8050697950b9f026cJeff Brown /** Window flag: Enable touches to slide out of a window into neighboring 89298db5fabdad86dca379740d8050697950b9f026cJeff Brown * windows in mid-gesture instead of being captured for the duration of 89398db5fabdad86dca379740d8050697950b9f026cJeff Brown * the gesture. 89498db5fabdad86dca379740d8050697950b9f026cJeff Brown * 89598db5fabdad86dca379740d8050697950b9f026cJeff Brown * This flag changes the behavior of touch focus for this window only. 89698db5fabdad86dca379740d8050697950b9f026cJeff Brown * Touches can slide out of the window but they cannot necessarily slide 89798db5fabdad86dca379740d8050697950b9f026cJeff Brown * back in (unless the other window with touch focus permits it). 89898db5fabdad86dca379740d8050697950b9f026cJeff Brown * 89998db5fabdad86dca379740d8050697950b9f026cJeff Brown * {@hide} 90098db5fabdad86dca379740d8050697950b9f026cJeff Brown */ 9016a591f585909415a1da431a2cc76b7732724037dAdam Lesinski public static final int FLAG_SLIPPERY = 0x20000000; 90298db5fabdad86dca379740d8050697950b9f026cJeff Brown 903e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler /** 904e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * Flag for a window belonging to an activity that responds to {@link KeyEvent#KEYCODE_MENU} 905e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * and therefore needs a Menu key. For devices where Menu is a physical button this flag is 906e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * ignored, but on devices where the Menu key is drawn in software it may be hidden unless 907e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * this flag is set. 908e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * 909e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * (Note that Action Bars, when available, are the preferred way to offer additional 910e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * functions otherwise accessed via an options menu.) 911e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * 912e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * {@hide} 913e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler */ 9146a591f585909415a1da431a2cc76b7732724037dAdam Lesinski public static final int FLAG_NEEDS_MENU_KEY = 0x40000000; 915e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler 9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9185d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Various behavioral options/flags. Default is none. 9195d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 9205d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_ALLOW_LOCK_WHILE_SCREEN_ON 9215d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_DIM_BEHIND 9225d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_FOCUSABLE 9235d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_TOUCHABLE 9245d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_TOUCH_MODAL 9255d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_TOUCHABLE_WHEN_WAKING 9265d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_KEEP_SCREEN_ON 9275d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_IN_SCREEN 9285d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_NO_LIMITS 9295d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_FULLSCREEN 9305d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_FORCE_NOT_FULLSCREEN 9315d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SECURE 9325d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SCALED 9335d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_IGNORE_CHEEK_PRESSES 9345d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_INSET_DECOR 9355d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_ALT_FOCUSABLE_IM 9365d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_WATCH_OUTSIDE_TOUCH 9375d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SHOW_WHEN_LOCKED 9385d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SHOW_WALLPAPER 9395d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_TURN_SCREEN_ON 9405d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_DISMISS_KEYGUARD 9415d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SPLIT_TOUCH 9425d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_HARDWARE_ACCELERATED 94330f420fd6a74ffa28b351b4aba74d44f5ea48ddakeunyoung * @see #FLAG_LOCAL_FOCUS_MODE 9445d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 9455d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.ExportedProperty(flagMapping = { 9465d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_ALLOW_LOCK_WHILE_SCREEN_ON, equals = FLAG_ALLOW_LOCK_WHILE_SCREEN_ON, 9475d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_ALLOW_LOCK_WHILE_SCREEN_ON"), 9485d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DIM_BEHIND, equals = FLAG_DIM_BEHIND, 9495d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DIM_BEHIND"), 9505d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_BLUR_BEHIND, equals = FLAG_BLUR_BEHIND, 9515d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_BLUR_BEHIND"), 9525d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_FOCUSABLE, equals = FLAG_NOT_FOCUSABLE, 9535d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_FOCUSABLE"), 9545d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_TOUCHABLE, equals = FLAG_NOT_TOUCHABLE, 9555d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_TOUCHABLE"), 9565d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_TOUCH_MODAL, equals = FLAG_NOT_TOUCH_MODAL, 9575d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_TOUCH_MODAL"), 9585d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_TOUCHABLE_WHEN_WAKING, equals = FLAG_TOUCHABLE_WHEN_WAKING, 9595d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_TOUCHABLE_WHEN_WAKING"), 9605d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_KEEP_SCREEN_ON, equals = FLAG_KEEP_SCREEN_ON, 9615d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_KEEP_SCREEN_ON"), 9625d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_IN_SCREEN, equals = FLAG_LAYOUT_IN_SCREEN, 9635d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_IN_SCREEN"), 9645d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_NO_LIMITS, equals = FLAG_LAYOUT_NO_LIMITS, 9655d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_NO_LIMITS"), 9665d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_FULLSCREEN, equals = FLAG_FULLSCREEN, 9675d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_FULLSCREEN"), 9685d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_FORCE_NOT_FULLSCREEN, equals = FLAG_FORCE_NOT_FULLSCREEN, 9695d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_FORCE_NOT_FULLSCREEN"), 9705d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DITHER, equals = FLAG_DITHER, 9715d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DITHER"), 9725d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SECURE, equals = FLAG_SECURE, 9735d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SECURE"), 9745d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SCALED, equals = FLAG_SCALED, 9755d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SCALED"), 9765d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_IGNORE_CHEEK_PRESSES, equals = FLAG_IGNORE_CHEEK_PRESSES, 9775d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_IGNORE_CHEEK_PRESSES"), 9785d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_INSET_DECOR, equals = FLAG_LAYOUT_INSET_DECOR, 9795d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_INSET_DECOR"), 9805d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_ALT_FOCUSABLE_IM, equals = FLAG_ALT_FOCUSABLE_IM, 9815d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_ALT_FOCUSABLE_IM"), 9825d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_WATCH_OUTSIDE_TOUCH, equals = FLAG_WATCH_OUTSIDE_TOUCH, 9835d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_WATCH_OUTSIDE_TOUCH"), 9845d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SHOW_WHEN_LOCKED, equals = FLAG_SHOW_WHEN_LOCKED, 9855d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SHOW_WHEN_LOCKED"), 9865d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SHOW_WALLPAPER, equals = FLAG_SHOW_WALLPAPER, 9875d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SHOW_WALLPAPER"), 9885d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_TURN_SCREEN_ON, equals = FLAG_TURN_SCREEN_ON, 9895d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_TURN_SCREEN_ON"), 9905d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DISMISS_KEYGUARD, equals = FLAG_DISMISS_KEYGUARD, 9915d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DISMISS_KEYGUARD"), 9925d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SPLIT_TOUCH, equals = FLAG_SPLIT_TOUCH, 9935d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SPLIT_TOUCH"), 9945d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_HARDWARE_ACCELERATED, equals = FLAG_HARDWARE_ACCELERATED, 99530f420fd6a74ffa28b351b4aba74d44f5ea48ddakeunyoung name = "FLAG_HARDWARE_ACCELERATED"), 99630f420fd6a74ffa28b351b4aba74d44f5ea48ddakeunyoung @ViewDebug.FlagToString(mask = FLAG_LOCAL_FOCUS_MODE, equals = FLAG_LOCAL_FOCUS_MODE, 997bd95740648372449a4d5c164d7050eee352d4c24John Spurlock name = "FLAG_LOCAL_FOCUS_MODE"), 998bd95740648372449a4d5c164d7050eee352d4c24John Spurlock @ViewDebug.FlagToString(mask = FLAG_TRANSLUCENT_STATUS, equals = FLAG_TRANSLUCENT_STATUS, 999bd95740648372449a4d5c164d7050eee352d4c24John Spurlock name = "FLAG_TRANSLUCENT_STATUS"), 1000bd95740648372449a4d5c164d7050eee352d4c24John Spurlock @ViewDebug.FlagToString(mask = FLAG_TRANSLUCENT_NAVIGATION, equals = FLAG_TRANSLUCENT_NAVIGATION, 1001bd95740648372449a4d5c164d7050eee352d4c24John Spurlock name = "FLAG_TRANSLUCENT_NAVIGATION") 10025d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn }) 10035d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int flags; 10045d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 10055d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 10065d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * If the window has requested hardware acceleration, but this is not 10075d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * allowed in the process it is in, then still render it as if it is 10085d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * hardware accelerated. This is used for the starting preview windows 10095d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * in the system process, which don't need to have the overhead of 10105d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * hardware acceleration (they are just a static rendering), but should 1011f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * be rendered as such to match the actual window of the app even if it 10125d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * is hardware accelerated. 10135d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Even if the window isn't hardware accelerated, still do its rendering 1014f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * as if it was. 10155d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Like {@link #FLAG_HARDWARE_ACCELERATED} except for trusted system windows 10165d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * that need hardware acceleration (e.g. LockScreen), where hardware acceleration 10175d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * is generally disabled. This flag must be specified in addition to 10185d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * {@link #FLAG_HARDWARE_ACCELERATED} to enable hardware acceleration for system 10195d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * windows. 10205d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 10215d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 10225d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 10235d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAG_FAKE_HARDWARE_ACCELERATED = 0x00000001; 10245d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 10255d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 10265d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * In the system process, we globally do not use hardware acceleration 1027f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * because there are many threads doing UI there and they conflict. 10285d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * If certain parts of the UI that really do want to use hardware 10295d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * acceleration, this flag can be set to force it. This is basically 10305d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * for the lock screen. Anyone else using it, you are probably wrong. 10315d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 10325d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 10335d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 10345d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAG_FORCE_HARDWARE_ACCELERATED = 0x00000002; 10355d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 10365d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 1037a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * By default, wallpapers are sent new offsets when the wallpaper is scrolled. Wallpapers 1038f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * may elect to skip these notifications if they are not doing anything productive with 1039a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * them (they do not affect the wallpaper scrolling operation) by calling 1040a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * {@link 1041a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * android.service.wallpaper.WallpaperService.Engine#setOffsetNotificationsEnabled(boolean)}. 1042a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * 1043a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * @hide 1044a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase */ 1045a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase public static final int PRIVATE_FLAG_WANTS_OFFSET_NOTIFICATIONS = 0x00000004; 1046a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase 1047a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase /** 104873ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * This is set for a window that has explicitly specified its 104973ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * FLAG_NEEDS_MENU_KEY, so we know the value on this window is the 105073ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * appropriate one to use. If this is not set, we should look at 105173ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * windows behind it to determine the appropriate value. 105273ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * 105373ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * @hide 105473ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn */ 105573ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn public static final int PRIVATE_FLAG_SET_NEEDS_MENU_KEY = 0x00000008; 105673ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn 105788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner /** In a multiuser system if this flag is set and the owner is a system process then this 105888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * window will appear on all user screens. This overrides the default behavior of window 105988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * types that normally only appear on the owning user's screen. Refer to each window type 106088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * to determine its default behavior. 106188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * 106288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * {@hide} */ 106388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner public static final int PRIVATE_FLAG_SHOW_FOR_ALL_USERS = 0x00000010; 106488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner 106573ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn /** 1066891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * Special flag for the volume overlay: force the window manager out of "hide nav bar" 1067891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * mode while the window is on screen. 1068891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * 1069891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn * {@hide} */ 1070891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn public static final int PRIVATE_FLAG_FORCE_SHOW_NAV_BAR = 0x00000020; 1071891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn 1072891d3fbb15683e72432af16e571f41f566d5fdf0Dianne Hackborn /** 10731c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn * Never animate position changes of the window. 10741c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn * 10751c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn * {@hide} */ 10761c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn public static final int PRIVATE_FLAG_NO_MOVE_ANIMATION = 0x00000040; 10771c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn 10786a591f585909415a1da431a2cc76b7732724037dAdam Lesinski /** Window flag: special flag to limit the size of the window to be 10796a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * original size ([320x480] x density). Used to create window for applications 10806a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * running under compatibility mode. 10816a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * 10826a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * {@hide} */ 10836a591f585909415a1da431a2cc76b7732724037dAdam Lesinski public static final int PRIVATE_FLAG_COMPATIBLE_WINDOW = 0x00000080; 10846a591f585909415a1da431a2cc76b7732724037dAdam Lesinski 10856a591f585909415a1da431a2cc76b7732724037dAdam Lesinski /** Window flag: a special option intended for system dialogs. When 10866a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * this flag is set, the window will demand focus unconditionally when 10876a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * it is created. 10886a591f585909415a1da431a2cc76b7732724037dAdam Lesinski * {@hide} */ 10896a591f585909415a1da431a2cc76b7732724037dAdam Lesinski public static final int PRIVATE_FLAG_SYSTEM_ERROR = 0x00000100; 10906a591f585909415a1da431a2cc76b7732724037dAdam Lesinski 10913f7cd517aace5ca418a2e5c6bc7a33238a54597bJohn Spurlock /** Window flag: maintain the previous translucent decor state when this window 1092bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * becomes top-most. 1093bd95740648372449a4d5c164d7050eee352d4c24John Spurlock * {@hide} */ 1094bd95740648372449a4d5c164d7050eee352d4c24John Spurlock public static final int PRIVATE_FLAG_INHERIT_TRANSLUCENT_DECOR = 0x00000200; 1095bd95740648372449a4d5c164d7050eee352d4c24John Spurlock 10961c5383ce0b4e162ebc9ac7e29c8c39377724d45bDianne Hackborn /** 10975d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Control flags that are private to the platform. 10985d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 10995d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 11005d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int privateFlags; 11015d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 11025d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 11039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Given a particular set of window manager flags, determine whether 11049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * such a window may be a target for an input method when it has 11059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus. In particular, this checks the 11069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_NOT_FOCUSABLE} and {@link #FLAG_ALT_FOCUSABLE_IM} 11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * flags and returns true if the combination of the two corresponds 11089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to a window that needs to be behind the input method so that the 11099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user can type into it. 11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags The current window manager flags. 11129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Returns true if such a window should be behind/interact 11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * with an input method, false if not. 11159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean mayUseInputMethod(int flags) { 11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project switch (flags&(FLAG_NOT_FOCUSABLE|FLAG_ALT_FOCUSABLE_IM)) { 11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case 0: 11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case FLAG_NOT_FOCUSABLE|FLAG_ALT_FOCUSABLE_IM: 11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Mask for {@link #softInputMode} of the bits that determine the 11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * desired visibility state of the soft input area for this window. 11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MASK_STATE = 0x0f; 11309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: no state has been specified. 11339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_UNSPECIFIED = 0; 11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please don't change the state of 11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the soft input area. 11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_UNCHANGED = 1; 11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please hide any soft input 11449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * area when normally appropriate (when the user is navigating 11459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to your window). 11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_HIDDEN = 2; 11489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please always hide any 11519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * soft input area when this window receives focus. 11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_ALWAYS_HIDDEN = 3; 11549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please show the soft 11579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * input area when normally appropriate (when the user is navigating 11589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to your window). 11599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_VISIBLE = 4; 11619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please always make the 11649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * soft input area visible when this window receives input focus. 11659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_ALWAYS_VISIBLE = 5; 11679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Mask for {@link #softInputMode} of the bits that determine the 11709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * way that the window should be adjusted to accommodate the soft 11719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * input window. 11729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MASK_ADJUST = 0xf0; 11749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: nothing specified. 11769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The system will try to pick one or 11779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 11789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_UNSPECIFIED = 0x00; 11809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: set to allow the 11829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window to be resized when an input 11839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * method is shown, so that its contents are not covered by the input 1184f10e6331e3bf01653235d93aa523056c146a85a3Scott Main * method. This can <em>not</em> be combined with 11859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_PAN}; if 11869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * neither of these are set, then the system will try to pick one or 118745c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * the other depending on the contents of the window. If the window's 118845c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * layout parameter flags include {@link #FLAG_FULLSCREEN}, this 118945c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * value for {@link #softInputMode} will be ignored; the window will 119045c89c2fadeb0324a6ad34c955f9ae998182134bChet Haase * not resize, but will stay fullscreen. 11919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_RESIZE = 0x10; 11939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: set to have a window 11959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * pan when an input method is 11969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * shown, so it doesn't need to deal with resizing but just panned 11979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * by the framework to ensure the current input focus is visible. This 1198f10e6331e3bf01653235d93aa523056c146a85a3Scott Main * can <em>not</em> be combined with {@link #SOFT_INPUT_ADJUST_RESIZE}; if 11999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * neither of these are set, then the system will try to pick one or 12009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 12019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_PAN = 0x20; 12039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1204dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** Adjustment option for {@link #softInputMode}: set to have a window 1205dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * not adjust for a shown input method. The window will not be resized, 1206dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * and it will not be panned to make its focus visible. 1207dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1208dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final int SOFT_INPUT_ADJUST_NOTHING = 0x30; 1209dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 12109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Bit for {@link #softInputMode}: set when the user has navigated 12129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to the window. This is normally set automatically for 12139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you by the system, though you may want to set it in certain cases 12149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * when you are displaying a window yourself. This flag will always 12159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be cleared automatically after the window is displayed. 12169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_IS_FORWARD_NAVIGATION = 0x100; 1218fb73f79340375013225618a5d87f46b958f698efMike Lockwood 1219fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** 1220be2c4f92a990ca48ad6ede252343dd9574dfe505Gilles Debunne * Desired operating mode for any soft input area. May be any combination 12219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of: 12229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 12239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <ul> 12249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> One of the visibility states 12259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_UNSPECIFIED}, {@link #SOFT_INPUT_STATE_UNCHANGED}, 12269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_HIDDEN}, {@link #SOFT_INPUT_STATE_ALWAYS_VISIBLE}, or 12279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_VISIBLE}. 12289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> One of the adjustment options 12299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_UNSPECIFIED}, 12309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_RESIZE}, or 12319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_PAN}. 12321bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * </ul> 12331bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 12341bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * 12351bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * <p>This flag can be controlled in your theme through the 12361bf1af60a3ec3da69aafbe1fe93c17312cb3e00eDianne Hackborn * {@link android.R.attr#windowSoftInputMode} attribute.</p> 12379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int softInputMode; 12399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12418eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Placement of window within the screen as per {@link Gravity}. Both 12428eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 12438eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} and 12448eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#applyDisplay(int, android.graphics.Rect, android.graphics.Rect) 12458eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Gravity.applyDisplay} are used during window layout, with this value 12468eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * given as the desired gravity. For example you can specify 12478eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#DISPLAY_CLIP_HORIZONTAL Gravity.DISPLAY_CLIP_HORIZONTAL} and 12488eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#DISPLAY_CLIP_VERTICAL Gravity.DISPLAY_CLIP_VERTICAL} here 12498eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * to control the behavior of 12508eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#applyDisplay(int, android.graphics.Rect, android.graphics.Rect) 12518eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Gravity.applyDisplay}. 12529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 12539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see Gravity 12549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int gravity; 12569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The horizontal margin, as a percentage of the container's width, 12598eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * between the container and the widget. See 12608eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 12618eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} for how this is used. This 12628eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * field is added with {@link #x} to supply the <var>xAdj</var> parameter. 12639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float horizontalMargin; 12659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The vertical margin, as a percentage of the container's height, 12688eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * between the container and the widget. See 12698eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 12708eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} for how this is used. This 12718eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * field is added with {@link #y} to supply the <var>yAdj</var> parameter. 12729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float verticalMargin; 12749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The desired bitmap format. May be one of the constants in 12779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.graphics.PixelFormat}. Default is OPAQUE. 12789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int format; 12809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * A style resource defining the animations to use for this window. 12839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This must be a system resource; it can not be an application resource 12849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * because the window manager does not have access to applications. 12859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int windowAnimations; 12879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An alpha value to apply to this entire window. 12909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An alpha of 1.0 means fully opaque and 0.0 means fully transparent 12919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float alpha = 1.0f; 12939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When {@link #FLAG_DIM_BEHIND} is set, this is the amount of dimming 12969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to apply. Range is from 1.0 for completely opaque to 0.0 for no 12979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * dim. 12989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float dimAmount = 1.0f; 1300dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1301dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1302dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Default value for {@link #screenBrightness} and {@link #buttonBrightness} 1303dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the brightness value is not overridden for this window 1304dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * and normal brightness policy should be used. 1305dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1306dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_NONE = -1.0f; 1307dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1308dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1309dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Value for {@link #screenBrightness} and {@link #buttonBrightness} 1310dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the screen or button backlight brightness should be set 1311dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * to the lowest value when this window is in front. 1312dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1313dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_OFF = 0.0f; 1314dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1315dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1316dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Value for {@link #screenBrightness} and {@link #buttonBrightness} 1317dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the screen or button backlight brightness should be set 1318dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * to the hightest value when this window is in front. 1319dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1320dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_FULL = 1.0f; 13219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 13239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This can be used to override the user's preferred brightness of 13249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the screen. A value of less than 0, the default, means to use the 13259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * preferred screen brightness. 0 to 1 adjusts the brightness from 13269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * dark to full bright. 13279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1328fb73f79340375013225618a5d87f46b958f698efMike Lockwood public float screenBrightness = BRIGHTNESS_OVERRIDE_NONE; 13299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1331fb73f79340375013225618a5d87f46b958f698efMike Lockwood * This can be used to override the standard behavior of the button and 1332fb73f79340375013225618a5d87f46b958f698efMike Lockwood * keyboard backlights. A value of less than 0, the default, means to 1333fb73f79340375013225618a5d87f46b958f698efMike Lockwood * use the standard backlight behavior. 0 to 1 adjusts the brightness 1334fb73f79340375013225618a5d87f46b958f698efMike Lockwood * from dark to full bright. 1335fb73f79340375013225618a5d87f46b958f698efMike Lockwood */ 1336fb73f79340375013225618a5d87f46b958f698efMike Lockwood public float buttonBrightness = BRIGHTNESS_OVERRIDE_NONE; 1337fb73f79340375013225618a5d87f46b958f698efMike Lockwood 1338fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** 13393c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * Value for {@link #rotationAnimation} to define the animation used to 13403c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * specify that this window will rotate in or out following a rotation. 13413c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 13423c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_ROTATE = 0; 13433c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 13443c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 13453c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * Value for {@link #rotationAnimation} to define the animation used to 13463c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * specify that this window will fade in or out following a rotation. 13473c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 13483c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_CROSSFADE = 1; 13493c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 13503c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 13513c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * Value for {@link #rotationAnimation} to define the animation used to 13523c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * specify that this window will immediately disappear or appear following 13533c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * a rotation. 13543c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 13553c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_JUMPCUT = 2; 13563c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 13573c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 1358bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * Define the exit and entry animations used on this window when the device is rotated. 1359bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * This only has an affect if the incoming and outgoing topmost 13603c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * opaque windows have the #FLAG_FULLSCREEN bit set and are not covered 1361bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * by other windows. All other situations default to the 1362bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * {@link #ROTATION_ANIMATION_ROTATE} behavior. 13633c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * 13643c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * @see #ROTATION_ANIMATION_ROTATE 13653c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * @see #ROTATION_ANIMATION_CROSSFADE 13663c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner * @see #ROTATION_ANIMATION_JUMPCUT 13673c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner */ 13683c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public int rotationAnimation = ROTATION_ANIMATION_ROTATE; 13693c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner 13703c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner /** 13719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Identifier for this window. This will usually be filled in for 13729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you. 13739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 13749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public IBinder token = null; 13759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 13779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Name of the package owning this window. 13789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 13799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String packageName = null; 13809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 13829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Specific orientation value for a window. 13839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * May be any of the same values allowed 13849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * for {@link android.content.pm.ActivityInfo#screenOrientation}. 13859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * If not set, a default value of 13869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.content.pm.ActivityInfo#SCREEN_ORIENTATION_UNSPECIFIED} 13879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be used. 13889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 13899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int screenOrientation = ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED; 1390664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1391664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** 1392664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * Control the visibility of the status bar. 139314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * 139414782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @see View#STATUS_BAR_VISIBLE 139514782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @see View#STATUS_BAR_HIDDEN 1396664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato */ 1397664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public int systemUiVisibility; 1398664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1399664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** 140014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @hide 140114782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * The ui visibility as requested by the views in this hierarchy. 140214782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * the combined value should be systemUiVisibility | subtreeSystemUiVisibility. 140314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato */ 140414782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato public int subtreeSystemUiVisibility; 140514782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato 140614782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato /** 1407664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * Get callbacks about the system ui visibility changing. 1408664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * 1409664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * TODO: Maybe there should be a bitfield of optional callbacks that we need. 1410664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * 1411664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * @hide 1412664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato */ 1413664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public boolean hasSystemUiListeners; 1414664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1415474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** 1416474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * When this window has focus, disable touch pad pointer gesture processing. 1417474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * The window will receive raw position updates from the touch pad instead 1418474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * of pointer movements and synthetic touch events. 1419474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * 1420474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @hide 1421474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown */ 1422474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public static final int INPUT_FEATURE_DISABLE_POINTER_GESTURES = 0x00000001; 1423474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 1424474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** 1425cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * Does not construct an input channel for this window. The channel will therefore 1426cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * be incapable of receiving input. 1427cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * 1428cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * @hide 1429cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown */ 1430cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown public static final int INPUT_FEATURE_NO_INPUT_CHANNEL = 0x00000002; 1431cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown 1432cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown /** 14331e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * When this window has focus, does not call user activity for all input events so 14341e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * the application will have to do it itself. Should only be used by 14351e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * the keyguard and phone app. 14361e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * <p> 14371e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Should only be used by the keyguard and phone app. 14381e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p> 14391e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * 14401e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @hide 14411e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown */ 14421e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public static final int INPUT_FEATURE_DISABLE_USER_ACTIVITY = 0x00000004; 14431e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 14441e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** 1445474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * Control special features of the input subsystem. 1446474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * 1447bdcc9a5811f9a037a3c4145b7469380d2dfe214bCraig Mautner * @see #INPUT_FEATURE_DISABLE_POINTER_GESTURES 1448cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * @see #INPUT_FEATURE_NO_INPUT_CHANNEL 14491e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @see #INPUT_FEATURE_DISABLE_USER_ACTIVITY 1450474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @hide 1451474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown */ 1452474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public int inputFeatures; 1453474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 14541e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** 14551e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Sets the number of milliseconds before the user activity timeout occurs 14561e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * when this window has focus. A value of -1 uses the standard timeout. 14571e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * A value of 0 uses the minimum support display timeout. 14581e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * <p> 14591e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * This property can only be used to reduce the user specified display timeout; 14601e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * it can never make the timeout longer than it normally would be. 14611e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p><p> 14621e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Should only be used by the keyguard and phone app. 14631e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p> 14641e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * 14651e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @hide 14661e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown */ 14671e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public long userActivityTimeout = -1; 14681e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 14699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams() { 1470980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = TYPE_APPLICATION; 14729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 14739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type) { 1476980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 14799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type, int _flags) { 1482980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 14869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type, int _flags, int _format) { 1489980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 14909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 14939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int w, int h, int _type, int _flags, int _format) { 14969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(w, h); 14979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 14989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 14999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 15009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int w, int h, int xpos, int ypos, int _type, 15039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int _flags, int _format) { 15049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(w, h); 15059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = xpos; 15069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = ypos; 15079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 15089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 15099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 15109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final void setTitle(CharSequence title) { 15139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (null == title) 15149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project title = ""; 15159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = TextUtils.stringOrSpannedString(title); 15179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final CharSequence getTitle() { 15209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mTitle; 15219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int describeContents() { 15249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return 0; 15259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void writeToParcel(Parcel out, int parcelableFlags) { 15289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(width); 15299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(height); 15309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(x); 15319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(y); 15329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(type); 15339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(flags); 15345d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn out.writeInt(privateFlags); 15359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(softInputMode); 15369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(gravity); 15379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(horizontalMargin); 15389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(verticalMargin); 15399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(format); 15409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(windowAnimations); 15419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(alpha); 15429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(dimAmount); 15439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(screenBrightness); 1544fb73f79340375013225618a5d87f46b958f698efMike Lockwood out.writeFloat(buttonBrightness); 15453c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner out.writeInt(rotationAnimation); 15469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeStrongBinder(token); 15479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeString(packageName); 15489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project TextUtils.writeToParcel(mTitle, out, parcelableFlags); 15499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(screenOrientation); 1550664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato out.writeInt(systemUiVisibility); 155114782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato out.writeInt(subtreeSystemUiVisibility); 1552664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato out.writeInt(hasSystemUiListeners ? 1 : 0); 1553474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown out.writeInt(inputFeatures); 15541e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown out.writeLong(userActivityTimeout); 15559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final Parcelable.Creator<LayoutParams> CREATOR 15589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project = new Parcelable.Creator<LayoutParams>() { 15599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams createFromParcel(Parcel in) { 15609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return new LayoutParams(in); 15619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams[] newArray(int size) { 15649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return new LayoutParams[size]; 15659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }; 15679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(Parcel in) { 15709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project width = in.readInt(); 15719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project height = in.readInt(); 15729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = in.readInt(); 15739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = in.readInt(); 15749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = in.readInt(); 15759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = in.readInt(); 15765d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn privateFlags = in.readInt(); 15779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project softInputMode = in.readInt(); 15789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project gravity = in.readInt(); 15799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalMargin = in.readFloat(); 15809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalMargin = in.readFloat(); 15819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = in.readInt(); 15829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project windowAnimations = in.readInt(); 15839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project alpha = in.readFloat(); 15849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dimAmount = in.readFloat(); 15859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenBrightness = in.readFloat(); 1586fb73f79340375013225618a5d87f46b958f698efMike Lockwood buttonBrightness = in.readFloat(); 15873c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner rotationAnimation = in.readInt(); 15889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project token = in.readStrongBinder(); 15899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project packageName = in.readString(); 15909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = TextUtils.CHAR_SEQUENCE_CREATOR.createFromParcel(in); 15919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenOrientation = in.readInt(); 1592664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato systemUiVisibility = in.readInt(); 159314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato subtreeSystemUiVisibility = in.readInt(); 1594664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato hasSystemUiListeners = in.readInt() != 0; 1595474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown inputFeatures = in.readInt(); 15961e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown userActivityTimeout = in.readLong(); 15979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15997299807d1895ea25cbe45d32b6edfd9a5723ee7aRomain Guy @SuppressWarnings({"PointlessBitwiseExpression"}) 16009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAYOUT_CHANGED = 1<<0; 16019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_CHANGED = 1<<1; 16029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAGS_CHANGED = 1<<2; 16039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FORMAT_CHANGED = 1<<3; 16049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ANIMATION_CHANGED = 1<<4; 16059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int DIM_AMOUNT_CHANGED = 1<<5; 16069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TITLE_CHANGED = 1<<6; 16079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ALPHA_CHANGED = 1<<7; 16089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_CHANGED = 1<<8; 16099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MODE_CHANGED = 1<<9; 16109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SCREEN_ORIENTATION_CHANGED = 1<<10; 16119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SCREEN_BRIGHTNESS_CHANGED = 1<<11; 16123c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int ROTATION_ANIMATION_CHANGED = 1<<12; 1613fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** {@hide} */ 16143c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int BUTTON_BRIGHTNESS_CHANGED = 1<<13; 1615664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** {@hide} */ 16163c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int SYSTEM_UI_VISIBILITY_CHANGED = 1<<14; 1617664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** {@hide} */ 16183c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int SYSTEM_UI_LISTENER_CHANGED = 1<<15; 1619474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** {@hide} */ 16203c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int INPUT_FEATURES_CHANGED = 1<<16; 16215d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** {@hide} */ 16223c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int PRIVATE_FLAGS_CHANGED = 1<<17; 1623f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy /** {@hide} */ 16243c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner public static final int USER_ACTIVITY_TIMEOUT_CHANGED = 1<<18; 16251e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** {@hide} */ 1626bd95740648372449a4d5c164d7050eee352d4c24John Spurlock public static final int TRANSLUCENT_FLAGS_CHANGED = 1<<19; 1627bd95740648372449a4d5c164d7050eee352d4c24John Spurlock /** {@hide} */ 1628f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy public static final int EVERYTHING_CHANGED = 0xffffffff; 1629f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy 1630e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima // internal buffer to backup/restore parameters under compatibility mode. 1631e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima private int[] mCompatibilityParamsBackup = null; 1632e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima 16339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final int copyFrom(LayoutParams o) { 16349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int changes = 0; 16359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 16369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (width != o.width) { 16379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project width = o.width; 163840e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (height != o.height) { 16419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project height = o.height; 164240e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (x != o.x) { 16459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = o.x; 16469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= LAYOUT_CHANGED; 16479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (y != o.y) { 16499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = o.y; 16509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= LAYOUT_CHANGED; 16519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (horizontalWeight != o.horizontalWeight) { 16539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalWeight = o.horizontalWeight; 165440e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (verticalWeight != o.verticalWeight) { 16579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalWeight = o.verticalWeight; 165840e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (horizontalMargin != o.horizontalMargin) { 16619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalMargin = o.horizontalMargin; 166240e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (verticalMargin != o.verticalMargin) { 16659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalMargin = o.verticalMargin; 166640e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (type != o.type) { 16699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = o.type; 16709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= TYPE_CHANGED; 16719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (flags != o.flags) { 1673bd95740648372449a4d5c164d7050eee352d4c24John Spurlock final int diff = flags ^ o.flags; 1674bd95740648372449a4d5c164d7050eee352d4c24John Spurlock if ((diff & (FLAG_TRANSLUCENT_STATUS | FLAG_TRANSLUCENT_NAVIGATION)) != 0) { 1675bd95740648372449a4d5c164d7050eee352d4c24John Spurlock changes |= TRANSLUCENT_FLAGS_CHANGED; 1676bd95740648372449a4d5c164d7050eee352d4c24John Spurlock } 16779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = o.flags; 167840e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= FLAGS_CHANGED; 16799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16805d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn if (privateFlags != o.privateFlags) { 16815d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn privateFlags = o.privateFlags; 16825d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn changes |= PRIVATE_FLAGS_CHANGED; 16835d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn } 16849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (softInputMode != o.softInputMode) { 16859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project softInputMode = o.softInputMode; 16869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= SOFT_INPUT_MODE_CHANGED; 16879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (gravity != o.gravity) { 16899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project gravity = o.gravity; 169040e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 16919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (format != o.format) { 16939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = o.format; 169440e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= FORMAT_CHANGED; 16959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (windowAnimations != o.windowAnimations) { 16979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project windowAnimations = o.windowAnimations; 16989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= ANIMATION_CHANGED; 16999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (token == null) { 17019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // NOTE: token only copied if the recipient doesn't 17029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // already have one. 17039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project token = o.token; 17049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (packageName == null) { 17069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // NOTE: packageName only copied if the recipient doesn't 17079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // already have one. 17089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project packageName = o.packageName; 17099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mTitle.equals(o.mTitle)) { 17119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = o.mTitle; 17129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= TITLE_CHANGED; 17139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (alpha != o.alpha) { 17159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project alpha = o.alpha; 17169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= ALPHA_CHANGED; 17179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (dimAmount != o.dimAmount) { 17199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dimAmount = o.dimAmount; 17209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= DIM_AMOUNT_CHANGED; 17219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenBrightness != o.screenBrightness) { 17239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenBrightness = o.screenBrightness; 17249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= SCREEN_BRIGHTNESS_CHANGED; 17259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1726fb73f79340375013225618a5d87f46b958f698efMike Lockwood if (buttonBrightness != o.buttonBrightness) { 1727fb73f79340375013225618a5d87f46b958f698efMike Lockwood buttonBrightness = o.buttonBrightness; 1728fb73f79340375013225618a5d87f46b958f698efMike Lockwood changes |= BUTTON_BRIGHTNESS_CHANGED; 1729fb73f79340375013225618a5d87f46b958f698efMike Lockwood } 17303c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner if (rotationAnimation != o.rotationAnimation) { 17313c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner rotationAnimation = o.rotationAnimation; 17323c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner changes |= ROTATION_ANIMATION_CHANGED; 17333c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner } 17349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 17359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenOrientation != o.screenOrientation) { 17369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenOrientation = o.screenOrientation; 173740e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= SCREEN_ORIENTATION_CHANGED; 17389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1739529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy 174014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato if (systemUiVisibility != o.systemUiVisibility 174114782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato || subtreeSystemUiVisibility != o.subtreeSystemUiVisibility) { 1742664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato systemUiVisibility = o.systemUiVisibility; 174314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato subtreeSystemUiVisibility = o.subtreeSystemUiVisibility; 1744664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato changes |= SYSTEM_UI_VISIBILITY_CHANGED; 1745664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1746664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1747664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (hasSystemUiListeners != o.hasSystemUiListeners) { 1748664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato hasSystemUiListeners = o.hasSystemUiListeners; 1749664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato changes |= SYSTEM_UI_LISTENER_CHANGED; 1750664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1751664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1752474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown if (inputFeatures != o.inputFeatures) { 1753474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown inputFeatures = o.inputFeatures; 1754474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown changes |= INPUT_FEATURES_CHANGED; 1755474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown } 1756474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 17571e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown if (userActivityTimeout != o.userActivityTimeout) { 17581e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown userActivityTimeout = o.userActivityTimeout; 17591e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown changes |= USER_ACTIVITY_TIMEOUT_CHANGED; 17601e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown } 17611e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 17629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return changes; 17639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 17659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 17669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String debug(String output) { 17679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project output += "Contents of " + this + ":"; 17689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", output); 17699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project output = super.debug(""); 17709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", output); 17719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", ""); 17729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", "WindowManager.LayoutParams={title=" + mTitle + "}"); 17739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return ""; 17749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 17769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 17779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String toString() { 17789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project StringBuilder sb = new StringBuilder(256); 17799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append("WM.LayoutParams{"); 17809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append("("); 17819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(x); 17829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(','); 17839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(y); 17849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(")("); 1785980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy sb.append((width== MATCH_PARENT ?"fill":(width==WRAP_CONTENT?"wrap":width))); 17869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append('x'); 1787980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy sb.append((height== MATCH_PARENT ?"fill":(height==WRAP_CONTENT?"wrap":height))); 17889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(")"); 17898eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (horizontalMargin != 0) { 17908eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" hm="); 17918eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(horizontalMargin); 17928eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 17938eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (verticalMargin != 0) { 17948eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" vm="); 17958eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(verticalMargin); 17969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (gravity != 0) { 17989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" gr=#"); 17999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(gravity)); 18009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 18018eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (softInputMode != 0) { 18028eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" sim=#"); 18038eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(Integer.toHexString(softInputMode)); 18048eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 18059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" ty="); 18069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(type); 18079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" fl=#"); 18089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(flags)); 18095d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn if (privateFlags != 0) { 181095c42974f719d1fac90fc0438eac778e9795681fAdam Lesinski if ((privateFlags & PRIVATE_FLAG_COMPATIBLE_WINDOW) != 0) { 181195c42974f719d1fac90fc0438eac778e9795681fAdam Lesinski sb.append(" compatible=true"); 181295c42974f719d1fac90fc0438eac778e9795681fAdam Lesinski } 18135d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn sb.append(" pfl=0x").append(Integer.toHexString(privateFlags)); 18145d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn } 1815a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn if (format != PixelFormat.OPAQUE) { 1816a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(" fmt="); 1817a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(format); 1818a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn } 18199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (windowAnimations != 0) { 18209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" wanim=0x"); 18219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(windowAnimations)); 18229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 18239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenOrientation != ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED) { 18249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" or="); 18259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(screenOrientation); 18269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 18278eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (alpha != 1.0f) { 18288eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" alpha="); 18298eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(alpha); 18308eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 18318eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (screenBrightness != BRIGHTNESS_OVERRIDE_NONE) { 18328eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" sbrt="); 18338eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(screenBrightness); 18348eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 18358eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (buttonBrightness != BRIGHTNESS_OVERRIDE_NONE) { 18368eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" bbrt="); 18378eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(buttonBrightness); 18388eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 18393c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner if (rotationAnimation != ROTATION_ANIMATION_ROTATE) { 18403c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner sb.append(" rotAnim="); 18413c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner sb.append(rotationAnimation); 18423c1743705c4df816089e07a17753c6043b4d8e66Craig Mautner } 1843664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (systemUiVisibility != 0) { 1844664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(" sysui=0x"); 1845664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(Integer.toHexString(systemUiVisibility)); 1846664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 184714782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato if (subtreeSystemUiVisibility != 0) { 184814782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato sb.append(" vsysui=0x"); 184914782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato sb.append(Integer.toHexString(subtreeSystemUiVisibility)); 185014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato } 1851664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (hasSystemUiListeners) { 1852664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(" sysuil="); 1853664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(hasSystemUiListeners); 1854664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1855a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn if (inputFeatures != 0) { 1856a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(" if=0x").append(Integer.toHexString(inputFeatures)); 1857a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn } 18581e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown if (userActivityTimeout >= 0) { 18591e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown sb.append(" userActivityTimeout=").append(userActivityTimeout); 18601e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown } 18619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append('}'); 18629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return sb.toString(); 18639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 18648d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima 18653d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima /** 18663d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima * Scale the layout params' coordinates and size. 186764f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima * @hide 1868e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 186964f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima public void scale(float scale) { 187061324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima x = (int) (x * scale + 0.5f); 187161324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima y = (int) (y * scale + 0.5f); 1872e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (width > 0) { 187361324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima width = (int) (width * scale + 0.5f); 1874e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima } 1875e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (height > 0) { 187661324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima height = (int) (height * scale + 0.5f); 18778d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima } 18788d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima } 18798d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima 18803d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima /** 1881e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * Backup the layout parameters used in compatibility mode. 1882e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * @see LayoutParams#restore() 1883e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 1884e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima void backup() { 1885e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima int[] backup = mCompatibilityParamsBackup; 1886e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (backup == null) { 188764f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima // we backup 4 elements, x, y, width, height 188864f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima backup = mCompatibilityParamsBackup = new int[4]; 18893d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 1890e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[0] = x; 1891e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[1] = y; 1892e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[2] = width; 1893e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[3] = height; 1894e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima } 1895e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima 1896e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima /** 1897e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * Restore the layout params' coordinates, size and gravity 1898e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * @see LayoutParams#backup() 1899e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 1900e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima void restore() { 1901e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima int[] backup = mCompatibilityParamsBackup; 1902e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (backup != null) { 1903e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima x = backup[0]; 1904e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima y = backup[1]; 1905e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima width = backup[2]; 19063d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima height = backup[3]; 19073d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 19083d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 19093d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima 19109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private CharSequence mTitle = ""; 19119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 19129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1913