19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License. 69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at 79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and 149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License. 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.view; 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 19a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brownimport android.app.Presentation; 20a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brownimport android.content.Context; 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ActivityInfo; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.PixelFormat; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.IBinder; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcel; 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcelable; 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.text.TextUtils; 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.Log; 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The interface that apps use to talk to the window manager. 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p> 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Use <code>Context.getSystemService(Context.WINDOW_SERVICE)</code> to get one of these. 34a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p><p> 35a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * Each window manager instance is bound to a particular {@link Display}. 36a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * To obtain a {@link WindowManager} for a different display, use 37a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link Context#createDisplayContext} to obtain a {@link Context} for that 38a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * display, then use <code>Context.getSystemService(Context.WINDOW_SERVICE)</code> 39a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * to get the WindowManager. 40a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p><p> 41a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * The simplest way to show a window on another display is to create a 42a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link Presentation}. The presentation will automatically obtain a 43a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link WindowManager} and {@link Context} for that display. 44a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p> 459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.content.Context#getSystemService 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.content.Context#WINDOW_SERVICE 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic interface WindowManager extends ViewManager { 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Exception that is thrown when trying to add view whose 529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams} {@link WindowManager.LayoutParams#token} 539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is invalid. 549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static class BadTokenException extends RuntimeException { 569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public BadTokenException() { 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public BadTokenException(String name) { 609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(name); 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 656018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner * Exception that is thrown when calling {@link #addView} to a secondary display that cannot 666018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner * be found. See {@link android.app.Presentation} for more information on secondary displays. 676018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner */ 686018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner public static class InvalidDisplayException extends RuntimeException { 696018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner public InvalidDisplayException() { 706018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner } 716018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner 726018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner public InvalidDisplayException(String name) { 736018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner super(name); 746018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner } 756018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner } 766018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner 776018aeec27914f138f36b00d8f00136a87562fd3Craig Mautner /** 78a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * Returns the {@link Display} upon which this {@link WindowManager} instance 79a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * will create new windows. 80a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * <p> 81a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * Despite the name of this method, the display that is returned is not 82a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * necessarily the primary display of the system (see {@link Display#DEFAULT_DISPLAY}). 83a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * The returned display could instead be a secondary display that this 84a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * window manager instance is managing. Think of it as the display that 85a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * this {@link WindowManager} instance uses by default. 86a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p><p> 87a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * To create windows on a different display, you need to obtain a 88a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * {@link WindowManager} for that {@link Display}. (See the {@link WindowManager} 89a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * class documentation for more information.) 90a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * </p> 91a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * 92a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown * @return The display that this window manager is managing. 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public Display getDefaultDisplay(); 95a492c3a7b2c18426fd0cb4d017eacbc368195dc5Jeff Brown 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Special variation of {@link #removeView} that immediately invokes 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the given view hierarchy's {@link View#onDetachedFromWindow() 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * View.onDetachedFromWindow()} methods before returning. This is not 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * for normal applications; using it correctly requires great care. 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The view to be removed. 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void removeViewImmediate(View view); 105d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static class LayoutParams extends ViewGroup.LayoutParams 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implements Parcelable { 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * X position for this window. With the default gravity it is ignored. 1109e3b002d3f9141d54948a65e0330fdcd09e75a30Fabrice Di Meglio * When using {@link Gravity#LEFT} or {@link Gravity#START} or {@link Gravity#RIGHT} or 1119e3b002d3f9141d54948a65e0330fdcd09e75a30Fabrice Di Meglio * {@link Gravity#END} it provides an offset from the given edge. 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 113529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int x; 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Y position for this window. With the default gravity it is ignored. 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When using {@link Gravity#TOP} or {@link Gravity#BOTTOM} it provides 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an offset from the given edge. 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 121529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int y; 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates how much of the extra space will be allocated horizontally 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to the view associated with these LayoutParams. Specify 0 if the view 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * should not be stretched. Otherwise the extra pixels will be pro-rated 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * among all views whose weight is greater than 0. 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 130529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float horizontalWeight; 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates how much of the extra space will be allocated vertically 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to the view associated with these LayoutParams. Specify 0 if the view 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * should not be stretched. Otherwise the extra pixels will be pro-rated 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * among all views whose weight is greater than 0. 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 139529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy @ViewDebug.ExportedProperty 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float verticalWeight; 141529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The general type of window. There are three main classes of 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window types: 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <ul> 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> <strong>Application windows</strong> (ranging from 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FIRST_APPLICATION_WINDOW} to 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #LAST_APPLICATION_WINDOW}) are normal top-level application 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows. For these types of windows, the {@link #token} must be 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set to the token of the activity they are a part of (this will 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * normally be done for you if {@link #token} is null). 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> <strong>Sub-windows</strong> (ranging from 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FIRST_SUB_WINDOW} to 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #LAST_SUB_WINDOW}) are associated with another top-level 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window. For these types of windows, the {@link #token} must be 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the token of the window it is attached to. 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> <strong>System windows</strong> (ranging from 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FIRST_SYSTEM_WINDOW} to 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #LAST_SYSTEM_WINDOW}) are special types of windows for 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * use by the system for specific purposes. They should not normally 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be used by applications, and a special permission is required 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to use them. 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * </ul> 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_BASE_APPLICATION 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_STARTING 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_PANEL 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_MEDIA 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_SUB_PANEL 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_APPLICATION_ATTACHED_DIALOG 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_STATUS_BAR 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SEARCH_BAR 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_PHONE 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_ALERT 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_KEYGUARD 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_TOAST 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_OVERLAY 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_PRIORITY_PHONE 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_STATUS_BAR_PANEL 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_DIALOG 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_KEYGUARD_DIALOG 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_SYSTEM_ERROR 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_INPUT_METHOD 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #TYPE_INPUT_METHOD_DIALOG 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1878f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.ExportedProperty(mapping = { 1888f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_BASE_APPLICATION, to = "TYPE_BASE_APPLICATION"), 1898f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION, to = "TYPE_APPLICATION"), 1908f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_STARTING, to = "TYPE_APPLICATION_STARTING"), 1918f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_PANEL, to = "TYPE_APPLICATION_PANEL"), 1928f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_MEDIA, to = "TYPE_APPLICATION_MEDIA"), 1938f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_SUB_PANEL, to = "TYPE_APPLICATION_SUB_PANEL"), 1948f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_APPLICATION_ATTACHED_DIALOG, to = "TYPE_APPLICATION_ATTACHED_DIALOG"), 195aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_APPLICATION_MEDIA_OVERLAY, to = "TYPE_APPLICATION_MEDIA_OVERLAY"), 1968f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_STATUS_BAR, to = "TYPE_STATUS_BAR"), 1978f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SEARCH_BAR, to = "TYPE_SEARCH_BAR"), 1988f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_PHONE, to = "TYPE_PHONE"), 1998f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_ALERT, to = "TYPE_SYSTEM_ALERT"), 2008f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_KEYGUARD, to = "TYPE_KEYGUARD"), 2018f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_TOAST, to = "TYPE_TOAST"), 2028f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_OVERLAY, to = "TYPE_SYSTEM_OVERLAY"), 2038f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_PRIORITY_PHONE, to = "TYPE_PRIORITY_PHONE"), 2048f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_DIALOG, to = "TYPE_SYSTEM_DIALOG"), 2058f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_KEYGUARD_DIALOG, to = "TYPE_KEYGUARD_DIALOG"), 2068f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_SYSTEM_ERROR, to = "TYPE_SYSTEM_ERROR"), 2078f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato @ViewDebug.IntToString(from = TYPE_INPUT_METHOD, to = "TYPE_INPUT_METHOD"), 2083b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown @ViewDebug.IntToString(from = TYPE_INPUT_METHOD_DIALOG, to = "TYPE_INPUT_METHOD_DIALOG"), 209bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_WALLPAPER, to = "TYPE_WALLPAPER"), 210bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_STATUS_BAR_PANEL, to = "TYPE_STATUS_BAR_PANEL"), 21129aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn @ViewDebug.IntToString(from = TYPE_SECURE_SYSTEM_OVERLAY, to = "TYPE_SECURE_SYSTEM_OVERLAY"), 212bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_DRAG, to = "TYPE_DRAG"), 213bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_STATUS_BAR_SUB_PANEL, to = "TYPE_STATUS_BAR_SUB_PANEL"), 214bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_POINTER, to = "TYPE_POINTER"), 215bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_NAVIGATION_BAR, to = "TYPE_NAVIGATION_BAR"), 216bfcb60ab0f696c8ef70830c365550e62fe2808bfJeff Brown @ViewDebug.IntToString(from = TYPE_VOLUME_OVERLAY, to = "TYPE_VOLUME_OVERLAY"), 217aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_BOOT_PROGRESS, to = "TYPE_BOOT_PROGRESS"), 218aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_HIDDEN_NAV_CONSUMER, to = "TYPE_HIDDEN_NAV_CONSUMER"), 219aeb7723a123dc09dc4ada55393a6c68858f45b3bScott Anderson @ViewDebug.IntToString(from = TYPE_DREAM, to = "TYPE_DREAM"), 220bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown @ViewDebug.IntToString(from = TYPE_NAVIGATION_BAR_PANEL, to = "TYPE_NAVIGATION_BAR_PANEL"), 2211cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov @ViewDebug.IntToString(from = TYPE_DISPLAY_OVERLAY, to = "TYPE_DISPLAY_OVERLAY"), 2221cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov @ViewDebug.IntToString(from = TYPE_MAGNIFICATION_OVERLAY, to = "TYPE_MAGNIFICATION_OVERLAY") 2238f2bd4328a7cc9dd70e597b7cc011be22c6ca566Joe Onorato }) 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int type; 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of window types that represent normal application windows. 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_APPLICATION_WINDOW = 1; 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: an application window that serves as the "base" window 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the overall application; all other application windows will 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * appear on top of it. 2355962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows only on the owning user's window. 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_BASE_APPLICATION = 1; 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a normal application window. The {@link #token} must be 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an Activity token identifying who the window belongs to. 2425962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows only on the owning user's window. 2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION = 2; 2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: special application window that is displayed while the 2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application is starting. Not for use by applications themselves; 2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this is used by the system to display something until the 2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application can show its own windows. 2515962b12bedc4a1d0354816c1cd6b06ba04f6d807Craig Mautner * In multiuser systems shows on all users' windows. 2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_STARTING = 3; 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of application windows. 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_APPLICATION_WINDOW = 99; 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of types of sub-windows. The {@link #token} of these windows 2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * must be set to the window they are attached to. These types of 2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are kept next to their attached window in Z-order, and their 2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * coordinate space is relative to their attached window. 2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_SUB_WINDOW = 1000; 2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a panel on top of an application window. These windows 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * appear on top of their attached window. 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_PANEL = FIRST_SUB_WINDOW; 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: window for showing media (e.g. video). These windows 2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are displayed behind their attached window. 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_MEDIA = FIRST_SUB_WINDOW+1; 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: a sub-panel on top of an application window. These 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are displayed on top their attached window and any 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #TYPE_APPLICATION_PANEL} panels. 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_SUB_PANEL = FIRST_SUB_WINDOW+2; 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window type: like {@link #TYPE_APPLICATION_PANEL}, but layout 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the window happens as that of a top-level window, <em>not</em> 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * as a child of its container. 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_APPLICATION_ATTACHED_DIALOG = FIRST_SUB_WINDOW+3; 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 294c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * Window type: window for showing overlays on top of media windows. 295c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * These windows are displayed between TYPE_APPLICATION_MEDIA and the 296c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * application window. They should be translucent to be useful. This 297c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * is a big ugly hack so: 298c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn * @hide 299c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn */ 300c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn public static final int TYPE_APPLICATION_MEDIA_OVERLAY = FIRST_SUB_WINDOW+4; 301c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn 302c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn /** 3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of sub-windows. 3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_SUB_WINDOW = 1999; 3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Start of system-specific window types. These are not normally 3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * created by applications. 3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FIRST_SYSTEM_WINDOW = 2000; 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: the status bar. There can be only one status bar 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window; it is placed at the top of the screen, and all other 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows are shifted down so they are below it. 31788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_STATUS_BAR = FIRST_SYSTEM_WINDOW; 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: the search bar. There can be only one search bar 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window; it is placed at the top of the screen. 32488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SEARCH_BAR = FIRST_SYSTEM_WINDOW+1; 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: phone. These are non-application windows providing 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user interaction with the phone (in particular incoming calls). 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * These windows are normally placed above all applications, but behind 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the status bar. 33388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_PHONE = FIRST_SYSTEM_WINDOW+2; 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: system window, such as low power alert. These windows 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are always on top of application windows. 34088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_ALERT = FIRST_SYSTEM_WINDOW+3; 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: keyguard window. 34688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_KEYGUARD = FIRST_SYSTEM_WINDOW+4; 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: transient notifications. 35288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_TOAST = FIRST_SYSTEM_WINDOW+5; 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: system overlay windows, which need to be displayed 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * on top of everything else. These windows must not take input 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus, or they will interfere with the keyguard. 36088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_OVERLAY = FIRST_SYSTEM_WINDOW+6; 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: priority phone UI, which needs to be displayed even if 3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the keyguard is active. These windows must not take input 3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus, or they will interfere with the keyguard. 36888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_PRIORITY_PHONE = FIRST_SYSTEM_WINDOW+7; 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: panel that slides out from the status bar 37488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_DIALOG = FIRST_SYSTEM_WINDOW+8; 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: dialogs that the keyguard shows 38088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_KEYGUARD_DIALOG = FIRST_SYSTEM_WINDOW+9; 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal system error windows, appear on top of 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * everything they can. 38788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_SYSTEM_ERROR = FIRST_SYSTEM_WINDOW+10; 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal input methods windows, which appear above 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the normal UI. Application windows may be resized or panned to keep 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the input focus visible while this window is displayed. 39588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_INPUT_METHOD = FIRST_SYSTEM_WINDOW+11; 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window type: internal input methods dialog windows, which appear above 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the current input method window. 40288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_INPUT_METHOD_DIALOG= FIRST_SYSTEM_WINDOW+12; 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4074c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * Window type: wallpaper window, placed behind any window that wants 4084c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * to sit on top of the wallpaper. 40988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4104c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 4114c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int TYPE_WALLPAPER = FIRST_SYSTEM_WINDOW+13; 4124c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn 4134c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn /** 41429fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato * Window type: panel that slides out from over the status bar 41588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 416badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn */ 417badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn public static final int TYPE_STATUS_BAR_PANEL = FIRST_SYSTEM_WINDOW+14; 4183b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown 4193b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown /** 4203b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * Window type: secure system overlay windows, which need to be displayed 4213b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * on top of everything else. These windows must not take input 4223b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * focus, or they will interfere with the keyguard. 4233b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * 4243b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * This is exactly like {@link #TYPE_SYSTEM_OVERLAY} except that only the 4253b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * system itself is allowed to create these overlays. Applications cannot 4263b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * obtain permission to create secure system overlays. 42788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * 42888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4293b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown * @hide 4303b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown */ 4313b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown public static final int TYPE_SECURE_SYSTEM_OVERLAY = FIRST_SYSTEM_WINDOW+15; 4323b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown 433badc47ecd1677d5f53bb16f8f30c158a879f5832Dianne Hackborn /** 434a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * Window type: the drag-and-drop pseudowindow. There is only one 435a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * drag layer (at most), and it is placed on top of all other windows. 43688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 437a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate * @hide 438a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate */ 4393b2b354ec1ba070eae13391d004d97a3e1403050Jeff Brown public static final int TYPE_DRAG = FIRST_SYSTEM_WINDOW+16; 440a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate 441a53146c5569f8ff5f7eb55e9ad35d23ddacf2addChristopher Tate /** 44229fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato * Window type: panel that slides out from under the status bar 44388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 444a89e903fd4b84778e1a7f2268fe025fe66a6e45eJoe Onorato * @hide 44529fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato */ 44629fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato public static final int TYPE_STATUS_BAR_SUB_PANEL = FIRST_SYSTEM_WINDOW+17; 44729fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato 44883c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown /** 44983c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown * Window type: (mouse) pointer 45088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 45183c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown * @hide 45283c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown */ 45383c09685f2e62bc3cf7e71bc61d903f4b9ccaeb4Jeff Brown public static final int TYPE_POINTER = FIRST_SYSTEM_WINDOW+18; 45429fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato 45529fc2c9705e1bb8ae098fca016032d2325031587Joe Onorato /** 4568956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler * Window type: Navigation bar (when distinct from status bar) 45788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 4588956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler * @hide 4598956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler */ 4608956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler public static final int TYPE_NAVIGATION_BAR = FIRST_SYSTEM_WINDOW+19; 4618956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler 4628956dbbc5f292d8b79072ae73b25f2114c8c7479Daniel Sandler /** 463e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * Window type: The volume level overlay/dialog shown when the user 464e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * changes the system volume. 46588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 466e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn * @hide 467e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn */ 468e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn public static final int TYPE_VOLUME_OVERLAY = FIRST_SYSTEM_WINDOW+20; 469e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn 470e8ecde10b33b1d050d2b63b3f4cd20e8bb7c96d4Dianne Hackborn /** 47129aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * Window type: The boot progress dialog, goes on top of everything 47229aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * in the world. 47388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 47429aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn * @hide 47529aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn */ 47629aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn public static final int TYPE_BOOT_PROGRESS = FIRST_SYSTEM_WINDOW+21; 47729aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn 47829aae6f36e565b8f2a99f2193597b964bb800ee8Dianne Hackborn /** 479df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * Window type: Fake window to consume touch events when the navigation 480df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * bar is hidden. 48188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 482df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn * @hide 483df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn */ 484df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn public static final int TYPE_HIDDEN_NAV_CONSUMER = FIRST_SYSTEM_WINDOW+22; 485df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn 486df89e65bf0fcc651d20b208c8d8d0b848fb43418Dianne Hackborn /** 4877d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler * Window type: Dreams (screen saver) window, just above keyguard. 48888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows only on the owning user's window. 4897d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler * @hide 4907d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler */ 4917d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler public static final int TYPE_DREAM = FIRST_SYSTEM_WINDOW+23; 4927d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler 4937d276c377ce0c56630c06a6da431a6cb9bd76d1eDaniel Sandler /** 494e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller * Window type: Navigation bar panel (when navigation bar is distinct from status bar) 49588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 496e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller * @hide 497e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller */ 498e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller public static final int TYPE_NAVIGATION_BAR_PANEL = FIRST_SYSTEM_WINDOW+24; 499e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller 500e898ac59db04d8ab0762180ca8ec7cea1347aa09Jim Miller /** 501a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn * Window type: Behind the universe of the real windows. 50288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 503a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn * @hide 504a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn */ 505a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn public static final int TYPE_UNIVERSE_BACKGROUND = FIRST_SYSTEM_WINDOW+25; 506a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn 507a4b7f2f75e7803193429ec1179fb5e2eb1c6fbdaDianne Hackborn /** 508bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown * Window type: Display overlay window. Used to simulate secondary display devices. 50988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 510bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown * @hide 511bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown */ 512bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown public static final int TYPE_DISPLAY_OVERLAY = FIRST_SYSTEM_WINDOW+26; 513bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown 514bd6e1500aedc5461e832f69e76341bff0e55fa2bJeff Brown /** 5151cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * Window type: Magnification overlay window. Used to highlight the magnified 5161cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * portion of a display when accessibility magnification is enabled. 51788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 5181cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov * @hide 5191cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov */ 5201cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov public static final int TYPE_MAGNIFICATION_OVERLAY = FIRST_SYSTEM_WINDOW+27; 5211cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov 5221cf70bbf96930662cab0e699d70b62865766ff52Svetoslav Ganov /** 52388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * Window type: Recents. Same layer as {@link #TYPE_SYSTEM_DIALOG} but only appears on 52488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * one user's screen. 52588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * In multiuser systems shows on all users' windows. 52688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * @hide 52788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner */ 52888400d3a31139c40c4014faf86c243647087ef6cCraig Mautner public static final int TYPE_RECENTS_OVERLAY = FIRST_SYSTEM_WINDOW+28; 52988400d3a31139c40c4014faf86c243647087ef6cCraig Mautner 53088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner /** 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * End of types of system windows. 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAST_SYSTEM_WINDOW = 2999; 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 535d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 536d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian @Deprecated 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_NORMAL = 0; 538d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 539317a6280cc109e873646e4652be1582d870eedfdMathias Agopian @Deprecated 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_HARDWARE = 1; 541d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 542317a6280cc109e873646e4652be1582d870eedfdMathias Agopian @Deprecated 5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_GPU = 2; 544d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian /** @deprecated this is ignored, this value is set automatically when needed. */ 545d2112306330ce0c162bee4b864991962ca2b655aMathias Agopian @Deprecated 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_PUSH_BUFFERS = 3; 5475d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5495d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @deprecated this is ignored 5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5515d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @Deprecated 5525d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int memoryType; 5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 554ef73162887943e16587b8e737b19e59348338e8cMike Lockwood /** Window flag: as long as this window is visible to the user, allow 555ef73162887943e16587b8e737b19e59348338e8cMike Lockwood * the lock screen to activate while the screen is on. 556ef73162887943e16587b8e737b19e59348338e8cMike Lockwood * This can be used independently, or in combination with 55795f7850a9d9c7c4f020d06986300f4740fb6a52cChristopher Tate * {@link #FLAG_KEEP_SCREEN_ON} and/or {@link #FLAG_SHOW_WHEN_LOCKED} */ 558ef73162887943e16587b8e737b19e59348338e8cMike Lockwood public static final int FLAG_ALLOW_LOCK_WHILE_SCREEN_ON = 0x00000001; 559ef73162887943e16587b8e737b19e59348338e8cMike Lockwood 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: everything behind this window will be dimmed. 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Use {@link #dimAmount} to control the amount of dim. */ 5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_DIM_BEHIND = 0x00000002; 5635d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5645d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** Window flag: blur everything behind this window. 5655d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @deprecated Blurring is no longer supported. */ 5665d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @Deprecated 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_BLUR_BEHIND = 0x00000004; 5685d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: this window won't ever get key input focus, so the 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user can not send key or other button events to it. Those will 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * instead go to whatever focusable window is behind it. This flag 5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will also enable {@link #FLAG_NOT_TOUCH_MODAL} whether or not that 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is explicitly set. 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>Setting this flag also implies that the window will not need to 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * interact with 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * a soft input method, so it will be Z-ordered and positioned 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * independently of any active input method (typically this means it 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * gets Z-ordered on top of the input method, so it can use the full 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen for its content and cover the input method if needed. You 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can use {@link #FLAG_ALT_FOCUSABLE_IM} to modify this behavior. */ 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_FOCUSABLE = 0x00000008; 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: this window can never receive touch events. */ 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_TOUCHABLE = 0x00000010; 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: Even when this window is focusable (its 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_NOT_FOCUSABLE is not set), allow any pointer events 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * outside of the window to be sent to the windows behind it. Otherwise 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * it will consume all pointer events itself, regardless of whether they 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * are inside of the window. */ 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_NOT_TOUCH_MODAL = 0x00000020; 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: When set, if the device is asleep when the touch 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen is pressed, you will receive this first touch event. Usually 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the first touch event is consumed by the system since the user can 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not see what they are pressing on. 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_TOUCHABLE_WHEN_WAKING = 0x00000040; 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: as long as this window is visible to the user, keep 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the device's screen turned on and bright. */ 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_KEEP_SCREEN_ON = 0x00000080; 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: place the window within the entire screen, ignoring 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * decorations around the border (a.k.a. the status bar). The 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window must correctly position its contents to take the screen 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * decoration into account. This flag is normally set for you 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * by Window as described in {@link Window#setFlags}. */ 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_IN_SCREEN = 0x00000100; 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: allow window to extend outside of the screen. */ 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_NO_LIMITS = 0x00000200; 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: Hide all screen decorations (e.g. status bar) while 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this window is displayed. This allows the window to use the entire 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * display space for itself -- the status bar will be hidden when 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an app window with this flag set is on the top layer. */ 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_FULLSCREEN = 0x00000400; 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: Override {@link #FLAG_FULLSCREEN and force the 6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen decorations (such as status bar) to be shown. */ 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_FORCE_NOT_FULLSCREEN = 0x00000800; 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: turn on dithering when compositing this window to 6263cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown * the screen. 6273cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown * @deprecated This flag is no longer used. */ 6283cc321ecf505d87850740ad3c63849e6793a8ef6Jeff Brown @Deprecated 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_DITHER = 0x00001000; 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 631f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown /** Window flag: Treat the content of the window as secure, preventing 632f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * it from appearing in screenshots or from being viewed on non-secure 633f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * displays. 634f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * 635f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * <p>See {@link android.view.Display#FLAG_SECURE} for more details about 636f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown * secure surfaces and secure displays. 637f0681b34dffc1510cbd9c3da5c3a7e695553fa8dJeff Brown */ 6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SECURE = 0x00002000; 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special mode where the layout parameters are used 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to perform scaling of the surface when it is composited to the 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen. */ 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SCALED = 0x00004000; 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: intended for windows that will often be used when the user is 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * holding the screen against their face, it will aggressively filter the event 6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * stream to prevent unintended presses in this situation that may not be 6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * desired for a particular window, when such an event stream is detected, the 6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * application will receive a CANCEL motion event to indicate this so applications 6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can handle this accordingly by taking no action on the event 6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * until the finger is released. */ 6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_IGNORE_CHEEK_PRESSES = 0x00008000; 6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special option only for use in combination with 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_LAYOUT_IN_SCREEN}. When requesting layout in the 6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * screen your window may appear on top of or behind screen decorations 6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * such as the status bar. By also including this flag, the window 6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * manager will report the inset rectangle needed to ensure your 6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * content is not covered by screen decorations. This flag is normally 6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set for you by Window as described in {@link Window#setFlags}.*/ 6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_LAYOUT_INSET_DECOR = 0x00010000; 6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: invert the state of {@link #FLAG_NOT_FOCUSABLE} with 6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * respect to how this window interacts with the current method. That 6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is, if FLAG_NOT_FOCUSABLE is set and this flag is set, then the 6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window will behave as if it needs to interact with the input method 6679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and thus be placed behind/away from it; if FLAG_NOT_FOCUSABLE is 6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not set and this flag is set, then the window will behave as if it 6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * doesn't need to interact with the input method and can be placed 6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to use more space and cover the input method. 6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_ALT_FOCUSABLE_IM = 0x00020000; 6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: if you have set {@link #FLAG_NOT_TOUCH_MODAL}, you 6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can set this flag to receive a single special MotionEvent with 6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the action 6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link MotionEvent#ACTION_OUTSIDE MotionEvent.ACTION_OUTSIDE} for 6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * touches that occur outside of your window. Note that you will not 6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * receive the full down/move/up gesture, only the location of the 6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * first down as an ACTION_OUTSIDE. 6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_WATCH_OUTSIDE_TOUCH = 0x00040000; 6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 684d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu /** Window flag: special flag to let windows be shown when the screen 685d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * is locked. This will let application windows take precedence over 686d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * key guard or any other lock screens. Can be used with 687d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu * {@link #FLAG_KEEP_SCREEN_ON} to turn screen on and display windows 6889bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * directly before showing the key guard window. Can be used with 6899bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * {@link #FLAG_DISMISS_KEYGUARD} to automatically fully dismisss 6909bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * non-secure keyguards. This flag only applies to the top-most 6919bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * full-screen window. 6924c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 693d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu public static final int FLAG_SHOW_WHEN_LOCKED = 0x00080000; 694d1a9337380cf9f40f1aa095457b11242d483295dSuchi Amalapurapu 6954c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn /** Window flag: ask that the system wallpaper be shown behind 6964c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * your window. The window surface must be translucent to be able 6974c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * to actually see the wallpaper behind it; this flag just ensures 6984c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * that the wallpaper surface will be there if this window actually 6994c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn * has translucent regions. 7004c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn */ 7014c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int FLAG_SHOW_WALLPAPER = 0x00100000; 7024c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn 70393e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn /** Window flag: when set as a window is being added or made 70493e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * visible, once the window has been shown then the system will 70593e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * poke the power manager's user activity (as if the user had woken 70693e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn * up the device) to turn the screen on. */ 70793e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn public static final int FLAG_TURN_SCREEN_ON = 0x00200000; 70893e462b79d6896da10e15e74c5aec6beb098dddfDianne Hackborn 7099bfb707597898f54722460b48588007b682f3e2aDianne Hackborn /** Window flag: when set the window will cause the keyguard to 7109bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * be dismissed, only if it is not a secure lock keyguard. Because such 7119bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * a keyguard is not needed for security, it will never re-appear if 7129bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * the user navigates to another window (in contrast to 7139bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * {@link #FLAG_SHOW_WHEN_LOCKED}, which will only temporarily 7149bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * hide both secure and non-secure keyguards but ensure they reappear 7159bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * when the user moves to another UI that doesn't hide them). 7169bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * If the keyguard is currently active and is secure (requires an 7179bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * unlock pattern) than the user will still need to confirm it before 7189bfb707597898f54722460b48588007b682f3e2aDianne Hackborn * seeing this window, unless {@link #FLAG_SHOW_WHEN_LOCKED} has 719ae069f76ee65fd5d9252c8191429fa55296d0208Daniel Sandler * also been set. 720ae069f76ee65fd5d9252c8191429fa55296d0208Daniel Sandler */ 7219bfb707597898f54722460b48588007b682f3e2aDianne Hackborn public static final int FLAG_DISMISS_KEYGUARD = 0x00400000; 72201ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown 72301ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown /** Window flag: when set the window will accept for touch events 72401ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * outside of its bounds to be sent to other windows that also 72501ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * support split touch. When this flag is not set, the first pointer 72601ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * that goes down determines the window to which all subsequent touches 72701ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * go until all pointers go up. When this flag is set, each pointer 72801ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * (not necessarily the first) that goes down determines the window 72901ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * to which all subsequent touches of that pointer will go until that 73001ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * pointer goes up thereby enabling touches with multiple pointers 73101ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown * to be split across multiple windows. 732d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn */ 73301ce2e9eee41cc0c24b0d16465710a28ea337d5dJeff Brown public static final int FLAG_SPLIT_TOUCH = 0x00800000; 734d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn 735d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn /** 73672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>Indicates whether this window should be hardware accelerated. 73772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * Requesting hardware acceleration does not guarantee it will happen.</p> 73872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * 73972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag can be controlled programmatically <em>only</em> to enable 74072f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * hardware acceleration. To enable hardware acceleration for a given 74172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * window programmatically, do the following:</p> 74272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * 74372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <pre> 74472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * Window w = activity.getWindow(); // in Activity's onCreate() for instance 74572f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * w.setFlags(WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED, 74672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED); 74772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * </pre> 74872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * 74972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>It is important to remember that this flag <strong>must</strong> 75072f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * be set before setting the content view of your activity or dialog.</p> 75172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * 75272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag cannot be used to disable hardware acceleration after it 75372f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * was enabled in your manifest using 75472f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * {@link android.R.attr#hardwareAccelerated}. If you need to selectively 75572f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * and programmatically disable hardware acceleration (for automated testing 75672f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * for instance), make sure it is turned off in your manifest and enable it 75772f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * on your activity or dialog when you need it instead, using the method 75872f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * described above.</p> 75972f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * 76072f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * <p>This flag is automatically set by the system if the 76172f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * {@link android.R.attr#hardwareAccelerated android:hardwareAccelerated} 76272f0a276ffd5f3d6513400e50de1a8bda547bed4Romain Guy * XML attribute is set to true on an activity or on the application.</p> 763d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn */ 764d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn public static final int FLAG_HARDWARE_ACCELERATED = 0x01000000; 765611fae4c39edbeb23b53f789a0219c539cf32fa6Daniel Sandler 766d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn // ----- HIDDEN FLAGS. 767d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn // These start at the high bit and go down. 76898db5fabdad86dca379740d8050697950b9f026cJeff Brown 76998db5fabdad86dca379740d8050697950b9f026cJeff Brown /** Window flag: Enable touches to slide out of a window into neighboring 77098db5fabdad86dca379740d8050697950b9f026cJeff Brown * windows in mid-gesture instead of being captured for the duration of 77198db5fabdad86dca379740d8050697950b9f026cJeff Brown * the gesture. 77298db5fabdad86dca379740d8050697950b9f026cJeff Brown * 77398db5fabdad86dca379740d8050697950b9f026cJeff Brown * This flag changes the behavior of touch focus for this window only. 77498db5fabdad86dca379740d8050697950b9f026cJeff Brown * Touches can slide out of the window but they cannot necessarily slide 77598db5fabdad86dca379740d8050697950b9f026cJeff Brown * back in (unless the other window with touch focus permits it). 77698db5fabdad86dca379740d8050697950b9f026cJeff Brown * 77798db5fabdad86dca379740d8050697950b9f026cJeff Brown * {@hide} 77898db5fabdad86dca379740d8050697950b9f026cJeff Brown */ 77998db5fabdad86dca379740d8050697950b9f026cJeff Brown public static final int FLAG_SLIPPERY = 0x04000000; 78098db5fabdad86dca379740d8050697950b9f026cJeff Brown 781e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler /** 782e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * Flag for a window belonging to an activity that responds to {@link KeyEvent#KEYCODE_MENU} 783e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * and therefore needs a Menu key. For devices where Menu is a physical button this flag is 784e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * ignored, but on devices where the Menu key is drawn in software it may be hidden unless 785e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * this flag is set. 786e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * 787e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * (Note that Action Bars, when available, are the preferred way to offer additional 788e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * functions otherwise accessed via an options menu.) 789e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * 790e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler * {@hide} 791e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler */ 792d9b3b7e8e1d8c919c3e5f5851daa80a2651ea7d1Dianne Hackborn public static final int FLAG_NEEDS_MENU_KEY = 0x08000000; 793e02d808abf370965c3c4e4d38af11bc69110fde2Daniel Sandler 7941ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima /** Window flag: special flag to limit the size of the window to be 7951ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * original size ([320x480] x density). Used to create window for applications 7961ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * running under compatibility mode. 7971ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * 7981ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima * {@hide} */ 7994c62fc0e1e5ea9c69a12a7d1cf8b3ec8b2d114a3Dianne Hackborn public static final int FLAG_COMPATIBLE_WINDOW = 0x20000000; 8001ecf5d28817f0a051e77488380dcd5bc622ea169Mitsuru Oshima 8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Window flag: a special option intended for system dialogs. When 8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * this flag is set, the window will demand focus unconditionally when 8039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * it is created. 8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@hide} */ 8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAG_SYSTEM_ERROR = 0x40000000; 8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 8085d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Various behavioral options/flags. Default is none. 8095d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 8105d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_ALLOW_LOCK_WHILE_SCREEN_ON 8115d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_DIM_BEHIND 8125d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_FOCUSABLE 8135d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_TOUCHABLE 8145d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_NOT_TOUCH_MODAL 8155d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_TOUCHABLE_WHEN_WAKING 8165d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_KEEP_SCREEN_ON 8175d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_IN_SCREEN 8185d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_NO_LIMITS 8195d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_FULLSCREEN 8205d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_FORCE_NOT_FULLSCREEN 8215d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SECURE 8225d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SCALED 8235d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_IGNORE_CHEEK_PRESSES 8245d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_LAYOUT_INSET_DECOR 8255d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_ALT_FOCUSABLE_IM 8265d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_WATCH_OUTSIDE_TOUCH 8275d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SHOW_WHEN_LOCKED 8285d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SHOW_WALLPAPER 8295d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_TURN_SCREEN_ON 8305d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_DISMISS_KEYGUARD 8315d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_SPLIT_TOUCH 8325d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @see #FLAG_HARDWARE_ACCELERATED 8335d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 8345d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.ExportedProperty(flagMapping = { 8355d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_ALLOW_LOCK_WHILE_SCREEN_ON, equals = FLAG_ALLOW_LOCK_WHILE_SCREEN_ON, 8365d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_ALLOW_LOCK_WHILE_SCREEN_ON"), 8375d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DIM_BEHIND, equals = FLAG_DIM_BEHIND, 8385d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DIM_BEHIND"), 8395d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_BLUR_BEHIND, equals = FLAG_BLUR_BEHIND, 8405d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_BLUR_BEHIND"), 8415d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_FOCUSABLE, equals = FLAG_NOT_FOCUSABLE, 8425d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_FOCUSABLE"), 8435d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_TOUCHABLE, equals = FLAG_NOT_TOUCHABLE, 8445d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_TOUCHABLE"), 8455d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_NOT_TOUCH_MODAL, equals = FLAG_NOT_TOUCH_MODAL, 8465d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_NOT_TOUCH_MODAL"), 8475d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_TOUCHABLE_WHEN_WAKING, equals = FLAG_TOUCHABLE_WHEN_WAKING, 8485d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_TOUCHABLE_WHEN_WAKING"), 8495d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_KEEP_SCREEN_ON, equals = FLAG_KEEP_SCREEN_ON, 8505d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_KEEP_SCREEN_ON"), 8515d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_IN_SCREEN, equals = FLAG_LAYOUT_IN_SCREEN, 8525d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_IN_SCREEN"), 8535d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_NO_LIMITS, equals = FLAG_LAYOUT_NO_LIMITS, 8545d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_NO_LIMITS"), 8555d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_FULLSCREEN, equals = FLAG_FULLSCREEN, 8565d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_FULLSCREEN"), 8575d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_FORCE_NOT_FULLSCREEN, equals = FLAG_FORCE_NOT_FULLSCREEN, 8585d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_FORCE_NOT_FULLSCREEN"), 8595d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DITHER, equals = FLAG_DITHER, 8605d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DITHER"), 8615d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SECURE, equals = FLAG_SECURE, 8625d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SECURE"), 8635d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SCALED, equals = FLAG_SCALED, 8645d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SCALED"), 8655d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_IGNORE_CHEEK_PRESSES, equals = FLAG_IGNORE_CHEEK_PRESSES, 8665d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_IGNORE_CHEEK_PRESSES"), 8675d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_LAYOUT_INSET_DECOR, equals = FLAG_LAYOUT_INSET_DECOR, 8685d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_LAYOUT_INSET_DECOR"), 8695d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_ALT_FOCUSABLE_IM, equals = FLAG_ALT_FOCUSABLE_IM, 8705d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_ALT_FOCUSABLE_IM"), 8715d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_WATCH_OUTSIDE_TOUCH, equals = FLAG_WATCH_OUTSIDE_TOUCH, 8725d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_WATCH_OUTSIDE_TOUCH"), 8735d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SHOW_WHEN_LOCKED, equals = FLAG_SHOW_WHEN_LOCKED, 8745d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SHOW_WHEN_LOCKED"), 8755d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SHOW_WALLPAPER, equals = FLAG_SHOW_WALLPAPER, 8765d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SHOW_WALLPAPER"), 8775d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_TURN_SCREEN_ON, equals = FLAG_TURN_SCREEN_ON, 8785d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_TURN_SCREEN_ON"), 8795d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_DISMISS_KEYGUARD, equals = FLAG_DISMISS_KEYGUARD, 8805d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_DISMISS_KEYGUARD"), 8815d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_SPLIT_TOUCH, equals = FLAG_SPLIT_TOUCH, 8825d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_SPLIT_TOUCH"), 8835d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn @ViewDebug.FlagToString(mask = FLAG_HARDWARE_ACCELERATED, equals = FLAG_HARDWARE_ACCELERATED, 8845d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn name = "FLAG_HARDWARE_ACCELERATED") 8855d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn }) 8865d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int flags; 8875d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 8885d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 8895d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * If the window has requested hardware acceleration, but this is not 8905d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * allowed in the process it is in, then still render it as if it is 8915d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * hardware accelerated. This is used for the starting preview windows 8925d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * in the system process, which don't need to have the overhead of 8935d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * hardware acceleration (they are just a static rendering), but should 894f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * be rendered as such to match the actual window of the app even if it 8955d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * is hardware accelerated. 8965d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Even if the window isn't hardware accelerated, still do its rendering 897f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * as if it was. 8985d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Like {@link #FLAG_HARDWARE_ACCELERATED} except for trusted system windows 8995d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * that need hardware acceleration (e.g. LockScreen), where hardware acceleration 9005d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * is generally disabled. This flag must be specified in addition to 9015d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * {@link #FLAG_HARDWARE_ACCELERATED} to enable hardware acceleration for system 9025d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * windows. 9035d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 9045d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 9055d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 9065d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAG_FAKE_HARDWARE_ACCELERATED = 0x00000001; 9075d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 9085d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 9095d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * In the system process, we globally do not use hardware acceleration 910f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * because there are many threads doing UI there and they conflict. 9115d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * If certain parts of the UI that really do want to use hardware 9125d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * acceleration, this flag can be set to force it. This is basically 9135d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * for the lock screen. Anyone else using it, you are probably wrong. 9145d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * 9155d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 9165d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 9175d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAG_FORCE_HARDWARE_ACCELERATED = 0x00000002; 9185d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 9195d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 920a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * By default, wallpapers are sent new offsets when the wallpaper is scrolled. Wallpapers 921f76a50ce8fdc6aea22cabc77b2977a1a15a79630Ken Wakasa * may elect to skip these notifications if they are not doing anything productive with 922a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * them (they do not affect the wallpaper scrolling operation) by calling 923a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * {@link 924a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * android.service.wallpaper.WallpaperService.Engine#setOffsetNotificationsEnabled(boolean)}. 925a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * 926a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase * @hide 927a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase */ 928a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase public static final int PRIVATE_FLAG_WANTS_OFFSET_NOTIFICATIONS = 0x00000004; 929a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase 930a8e5a2bcd6a0d35893187c6df42425c03be005daChet Haase /** 93173ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * This is set for a window that has explicitly specified its 93273ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * FLAG_NEEDS_MENU_KEY, so we know the value on this window is the 93373ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * appropriate one to use. If this is not set, we should look at 93473ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * windows behind it to determine the appropriate value. 93573ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * 93673ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn * @hide 93773ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn */ 93873ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn public static final int PRIVATE_FLAG_SET_NEEDS_MENU_KEY = 0x00000008; 93973ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn 94088400d3a31139c40c4014faf86c243647087ef6cCraig Mautner /** In a multiuser system if this flag is set and the owner is a system process then this 94188400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * window will appear on all user screens. This overrides the default behavior of window 94288400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * types that normally only appear on the owning user's screen. Refer to each window type 94388400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * to determine its default behavior. 94488400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * 94588400d3a31139c40c4014faf86c243647087ef6cCraig Mautner * {@hide} */ 94688400d3a31139c40c4014faf86c243647087ef6cCraig Mautner public static final int PRIVATE_FLAG_SHOW_FOR_ALL_USERS = 0x00000010; 94788400d3a31139c40c4014faf86c243647087ef6cCraig Mautner 94873ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn /** 9495d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * Control flags that are private to the platform. 9505d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn * @hide 9515d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn */ 9525d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public int privateFlags; 9535d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn 9545d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** 9559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Given a particular set of window manager flags, determine whether 9569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * such a window may be a target for an input method when it has 9579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * focus. In particular, this checks the 9589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #FLAG_NOT_FOCUSABLE} and {@link #FLAG_ALT_FOCUSABLE_IM} 9599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * flags and returns true if the combination of the two corresponds 9609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to a window that needs to be behind the input method so that the 9619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * user can type into it. 9629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags The current window manager flags. 9649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Returns true if such a window should be behind/interact 9669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * with an input method, false if not. 9679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean mayUseInputMethod(int flags) { 9699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project switch (flags&(FLAG_NOT_FOCUSABLE|FLAG_ALT_FOCUSABLE_IM)) { 9709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case 0: 9719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case FLAG_NOT_FOCUSABLE|FLAG_ALT_FOCUSABLE_IM: 9729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 9739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 9759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Mask for {@link #softInputMode} of the bits that determine the 9799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * desired visibility state of the soft input area for this window. 9809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MASK_STATE = 0x0f; 9829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: no state has been specified. 9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_UNSPECIFIED = 0; 9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please don't change the state of 9909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the soft input area. 9919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_UNCHANGED = 1; 9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please hide any soft input 9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * area when normally appropriate (when the user is navigating 9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to your window). 9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_HIDDEN = 2; 10009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please always hide any 10039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * soft input area when this window receives focus. 10049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_ALWAYS_HIDDEN = 3; 10069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please show the soft 10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * input area when normally appropriate (when the user is navigating 10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to your window). 10119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_VISIBLE = 4; 10139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Visibility state for {@link #softInputMode}: please always make the 10169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * soft input area visible when this window receives input focus. 10179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_STATE_ALWAYS_VISIBLE = 5; 10199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Mask for {@link #softInputMode} of the bits that determine the 10229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * way that the window should be adjusted to accommodate the soft 10239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * input window. 10249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MASK_ADJUST = 0xf0; 10269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: nothing specified. 10289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The system will try to pick one or 10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_UNSPECIFIED = 0x00; 10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: set to allow the 10349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window to be resized when an input 10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * method is shown, so that its contents are not covered by the input 1036f10e6331e3bf01653235d93aa523056c146a85a3Scott Main * method. This can <em>not</em> be combined with 10379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_PAN}; if 10389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * neither of these are set, then the system will try to pick one or 10399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_RESIZE = 0x10; 10429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Adjustment option for {@link #softInputMode}: set to have a window 10449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * pan when an input method is 10459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * shown, so it doesn't need to deal with resizing but just panned 10469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * by the framework to ensure the current input focus is visible. This 1047f10e6331e3bf01653235d93aa523056c146a85a3Scott Main * can <em>not</em> be combined with {@link #SOFT_INPUT_ADJUST_RESIZE}; if 10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * neither of these are set, then the system will try to pick one or 10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the other depending on the contents of the window. 10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_ADJUST_PAN = 0x20; 10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1053dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** Adjustment option for {@link #softInputMode}: set to have a window 1054dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * not adjust for a shown input method. The window will not be resized, 1055dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * and it will not be panned to make its focus visible. 1056dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1057dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final int SOFT_INPUT_ADJUST_NOTHING = 0x30; 1058dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Bit for {@link #softInputMode}: set when the user has navigated 10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * forward to the window. This is normally set automatically for 10629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you by the system, though you may want to set it in certain cases 10639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * when you are displaying a window yourself. This flag will always 10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be cleared automatically after the window is displayed. 10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_IS_FORWARD_NAVIGATION = 0x100; 1067fb73f79340375013225618a5d87f46b958f698efMike Lockwood 1068fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** 1069be2c4f92a990ca48ad6ede252343dd9574dfe505Gilles Debunne * Desired operating mode for any soft input area. May be any combination 10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of: 10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <ul> 10739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> One of the visibility states 10749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_UNSPECIFIED}, {@link #SOFT_INPUT_STATE_UNCHANGED}, 10759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_HIDDEN}, {@link #SOFT_INPUT_STATE_ALWAYS_VISIBLE}, or 10769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_STATE_VISIBLE}. 10779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <li> One of the adjustment options 10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_UNSPECIFIED}, 10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_RESIZE}, or 10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SOFT_INPUT_ADJUST_PAN}. 10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int softInputMode; 10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10858eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Placement of window within the screen as per {@link Gravity}. Both 10868eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 10878eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} and 10888eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#applyDisplay(int, android.graphics.Rect, android.graphics.Rect) 10898eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Gravity.applyDisplay} are used during window layout, with this value 10908eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * given as the desired gravity. For example you can specify 10918eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#DISPLAY_CLIP_HORIZONTAL Gravity.DISPLAY_CLIP_HORIZONTAL} and 10928eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#DISPLAY_CLIP_VERTICAL Gravity.DISPLAY_CLIP_VERTICAL} here 10938eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * to control the behavior of 10948eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#applyDisplay(int, android.graphics.Rect, android.graphics.Rect) 10958eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * Gravity.applyDisplay}. 10969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see Gravity 10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int gravity; 11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The horizontal margin, as a percentage of the container's width, 11038eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * between the container and the widget. See 11048eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 11058eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} for how this is used. This 11068eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * field is added with {@link #x} to supply the <var>xAdj</var> parameter. 11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float horizontalMargin; 11099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The vertical margin, as a percentage of the container's height, 11128eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * between the container and the widget. See 11138eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * {@link Gravity#apply(int, int, int, android.graphics.Rect, int, int, 11148eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * android.graphics.Rect) Gravity.apply} for how this is used. This 11158eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn * field is added with {@link #y} to supply the <var>yAdj</var> parameter. 11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float verticalMargin; 11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The desired bitmap format. May be one of the constants in 11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.graphics.PixelFormat}. Default is OPAQUE. 11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int format; 11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * A style resource defining the animations to use for this window. 11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This must be a system resource; it can not be an application resource 11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * because the window manager does not have access to applications. 11299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int windowAnimations; 11319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An alpha value to apply to this entire window. 11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An alpha of 1.0 means fully opaque and 0.0 means fully transparent 11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float alpha = 1.0f; 11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When {@link #FLAG_DIM_BEHIND} is set, this is the amount of dimming 11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to apply. Range is from 1.0 for completely opaque to 0.0 for no 11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * dim. 11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public float dimAmount = 1.0f; 1144dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1145dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1146dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Default value for {@link #screenBrightness} and {@link #buttonBrightness} 1147dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the brightness value is not overridden for this window 1148dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * and normal brightness policy should be used. 1149dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1150dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_NONE = -1.0f; 1151dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1152dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1153dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Value for {@link #screenBrightness} and {@link #buttonBrightness} 1154dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the screen or button backlight brightness should be set 1155dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * to the lowest value when this window is in front. 1156dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1157dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_OFF = 0.0f; 1158dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn 1159dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn /** 1160dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * Value for {@link #screenBrightness} and {@link #buttonBrightness} 1161dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * indicating that the screen or button backlight brightness should be set 1162dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn * to the hightest value when this window is in front. 1163dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn */ 1164dea3ef7967228f0ddcc03f2455a4f1254758e584Dianne Hackborn public static final float BRIGHTNESS_OVERRIDE_FULL = 1.0f; 11659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This can be used to override the user's preferred brightness of 11689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the screen. A value of less than 0, the default, means to use the 11699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * preferred screen brightness. 0 to 1 adjusts the brightness from 11709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * dark to full bright. 11719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1172fb73f79340375013225618a5d87f46b958f698efMike Lockwood public float screenBrightness = BRIGHTNESS_OVERRIDE_NONE; 11739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1175fb73f79340375013225618a5d87f46b958f698efMike Lockwood * This can be used to override the standard behavior of the button and 1176fb73f79340375013225618a5d87f46b958f698efMike Lockwood * keyboard backlights. A value of less than 0, the default, means to 1177fb73f79340375013225618a5d87f46b958f698efMike Lockwood * use the standard backlight behavior. 0 to 1 adjusts the brightness 1178fb73f79340375013225618a5d87f46b958f698efMike Lockwood * from dark to full bright. 1179fb73f79340375013225618a5d87f46b958f698efMike Lockwood */ 1180fb73f79340375013225618a5d87f46b958f698efMike Lockwood public float buttonBrightness = BRIGHTNESS_OVERRIDE_NONE; 1181fb73f79340375013225618a5d87f46b958f698efMike Lockwood 1182fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** 11839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Identifier for this window. This will usually be filled in for 11849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you. 11859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public IBinder token = null; 11879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Name of the package owning this window. 11909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String packageName = null; 11929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Specific orientation value for a window. 11959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * May be any of the same values allowed 11969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * for {@link android.content.pm.ActivityInfo#screenOrientation}. 11979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * If not set, a default value of 11989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.content.pm.ActivityInfo#SCREEN_ORIENTATION_UNSPECIFIED} 11999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be used. 12009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int screenOrientation = ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED; 1202664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1203664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** 1204664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * Control the visibility of the status bar. 120514782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * 120614782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @see View#STATUS_BAR_VISIBLE 120714782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @see View#STATUS_BAR_HIDDEN 1208664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato */ 1209664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public int systemUiVisibility; 1210664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1211664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** 121214782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * @hide 121314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * The ui visibility as requested by the views in this hierarchy. 121414782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato * the combined value should be systemUiVisibility | subtreeSystemUiVisibility. 121514782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato */ 121614782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato public int subtreeSystemUiVisibility; 121714782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato 121814782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato /** 1219664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * Get callbacks about the system ui visibility changing. 1220664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * 1221664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * TODO: Maybe there should be a bitfield of optional callbacks that we need. 1222664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * 1223664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato * @hide 1224664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato */ 1225664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public boolean hasSystemUiListeners; 1226664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1227474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** 1228474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * When this window has focus, disable touch pad pointer gesture processing. 1229474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * The window will receive raw position updates from the touch pad instead 1230474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * of pointer movements and synthetic touch events. 1231474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * 1232474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @hide 1233474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown */ 1234474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public static final int INPUT_FEATURE_DISABLE_POINTER_GESTURES = 0x00000001; 1235474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 1236474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** 1237cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * Does not construct an input channel for this window. The channel will therefore 1238cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * be incapable of receiving input. 1239cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * 1240cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * @hide 1241cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown */ 1242cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown public static final int INPUT_FEATURE_NO_INPUT_CHANNEL = 0x00000002; 1243cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown 1244cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown /** 12451e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * When this window has focus, does not call user activity for all input events so 12461e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * the application will have to do it itself. Should only be used by 12471e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * the keyguard and phone app. 12481e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * <p> 12491e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Should only be used by the keyguard and phone app. 12501e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p> 12511e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * 12521e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @hide 12531e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown */ 12541e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public static final int INPUT_FEATURE_DISABLE_USER_ACTIVITY = 0x00000004; 12551e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 12561e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** 1257474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * Control special features of the input subsystem. 1258474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * 1259474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @see #INPUT_FEATURE_DISABLE_TOUCH_PAD_GESTURES 1260cc4f7db698f88b633a286d8ab1105b28a474cd09Jeff Brown * @see #INPUT_FEATURE_NO_INPUT_CHANNEL 12611e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @see #INPUT_FEATURE_DISABLE_USER_ACTIVITY 1262474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown * @hide 1263474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown */ 1264474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public int inputFeatures; 1265474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 12661e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** 12671e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Sets the number of milliseconds before the user activity timeout occurs 12681e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * when this window has focus. A value of -1 uses the standard timeout. 12691e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * A value of 0 uses the minimum support display timeout. 12701e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * <p> 12711e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * This property can only be used to reduce the user specified display timeout; 12721e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * it can never make the timeout longer than it normally would be. 12731e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p><p> 12741e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * Should only be used by the keyguard and phone app. 12751e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * </p> 12761e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * 12771e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown * @hide 12781e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown */ 12791e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public long userActivityTimeout = -1; 12801e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 12819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams() { 1282980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 12839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = TYPE_APPLICATION; 12849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 12859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type) { 1288980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 12899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 12909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 12919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type, int _flags) { 1294980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 12959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 12969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 12979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = PixelFormat.OPAQUE; 12989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int _type, int _flags, int _format) { 1301980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy super(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 13029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 13039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 13049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 13059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int w, int h, int _type, int _flags, int _format) { 13089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(w, h); 13099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 13109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 13119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 13129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(int w, int h, int xpos, int ypos, int _type, 13159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int _flags, int _format) { 13169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super(w, h); 13179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = xpos; 13189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = ypos; 13199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = _type; 13209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = _flags; 13219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = _format; 13229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final void setTitle(CharSequence title) { 13259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (null == title) 13269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project title = ""; 13279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = TextUtils.stringOrSpannedString(title); 13299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final CharSequence getTitle() { 13329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mTitle; 13339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int describeContents() { 13369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return 0; 13379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void writeToParcel(Parcel out, int parcelableFlags) { 13409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(width); 13419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(height); 13429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(x); 13439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(y); 13449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(type); 13459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(flags); 13465d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn out.writeInt(privateFlags); 13479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(softInputMode); 13489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(gravity); 13499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(horizontalMargin); 13509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(verticalMargin); 13519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(format); 13529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(windowAnimations); 13539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(alpha); 13549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(dimAmount); 13559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeFloat(screenBrightness); 1356fb73f79340375013225618a5d87f46b958f698efMike Lockwood out.writeFloat(buttonBrightness); 13579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeStrongBinder(token); 13589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeString(packageName); 13599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project TextUtils.writeToParcel(mTitle, out, parcelableFlags); 13609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project out.writeInt(screenOrientation); 1361664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato out.writeInt(systemUiVisibility); 136214782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato out.writeInt(subtreeSystemUiVisibility); 1363664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato out.writeInt(hasSystemUiListeners ? 1 : 0); 1364474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown out.writeInt(inputFeatures); 13651e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown out.writeLong(userActivityTimeout); 13669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final Parcelable.Creator<LayoutParams> CREATOR 13699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project = new Parcelable.Creator<LayoutParams>() { 13709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams createFromParcel(Parcel in) { 13719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return new LayoutParams(in); 13729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams[] newArray(int size) { 13759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return new LayoutParams[size]; 13769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 13779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }; 13789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 13809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LayoutParams(Parcel in) { 13819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project width = in.readInt(); 13829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project height = in.readInt(); 13839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = in.readInt(); 13849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = in.readInt(); 13859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = in.readInt(); 13869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = in.readInt(); 13875d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn privateFlags = in.readInt(); 13889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project softInputMode = in.readInt(); 13899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project gravity = in.readInt(); 13909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalMargin = in.readFloat(); 13919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalMargin = in.readFloat(); 13929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = in.readInt(); 13939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project windowAnimations = in.readInt(); 13949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project alpha = in.readFloat(); 13959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dimAmount = in.readFloat(); 13969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenBrightness = in.readFloat(); 1397fb73f79340375013225618a5d87f46b958f698efMike Lockwood buttonBrightness = in.readFloat(); 13989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project token = in.readStrongBinder(); 13999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project packageName = in.readString(); 14009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = TextUtils.CHAR_SEQUENCE_CREATOR.createFromParcel(in); 14019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenOrientation = in.readInt(); 1402664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato systemUiVisibility = in.readInt(); 140314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato subtreeSystemUiVisibility = in.readInt(); 1404664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato hasSystemUiListeners = in.readInt() != 0; 1405474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown inputFeatures = in.readInt(); 14061e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown userActivityTimeout = in.readLong(); 14079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14097299807d1895ea25cbe45d32b6edfd9a5723ee7aRomain Guy @SuppressWarnings({"PointlessBitwiseExpression"}) 14109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int LAYOUT_CHANGED = 1<<0; 14119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TYPE_CHANGED = 1<<1; 14129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FLAGS_CHANGED = 1<<2; 14139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FORMAT_CHANGED = 1<<3; 14149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ANIMATION_CHANGED = 1<<4; 14159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int DIM_AMOUNT_CHANGED = 1<<5; 14169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int TITLE_CHANGED = 1<<6; 14179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ALPHA_CHANGED = 1<<7; 14189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int MEMORY_TYPE_CHANGED = 1<<8; 14199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SOFT_INPUT_MODE_CHANGED = 1<<9; 14209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SCREEN_ORIENTATION_CHANGED = 1<<10; 14219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int SCREEN_BRIGHTNESS_CHANGED = 1<<11; 1422fb73f79340375013225618a5d87f46b958f698efMike Lockwood /** {@hide} */ 1423fb73f79340375013225618a5d87f46b958f698efMike Lockwood public static final int BUTTON_BRIGHTNESS_CHANGED = 1<<12; 1424664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** {@hide} */ 1425664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public static final int SYSTEM_UI_VISIBILITY_CHANGED = 1<<13; 1426664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato /** {@hide} */ 1427664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato public static final int SYSTEM_UI_LISTENER_CHANGED = 1<<14; 1428474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown /** {@hide} */ 1429474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown public static final int INPUT_FEATURES_CHANGED = 1<<15; 14305d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn /** {@hide} */ 14315d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn public static final int PRIVATE_FLAGS_CHANGED = 1<<16; 1432f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy /** {@hide} */ 14331e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown public static final int USER_ACTIVITY_TIMEOUT_CHANGED = 1<<17; 14341e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown /** {@hide} */ 1435f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy public static final int EVERYTHING_CHANGED = 0xffffffff; 1436f21c9b0f52d5a1de5050f90f0818467fad014eaaRomain Guy 1437e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima // internal buffer to backup/restore parameters under compatibility mode. 1438e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima private int[] mCompatibilityParamsBackup = null; 1439e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima 14409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final int copyFrom(LayoutParams o) { 14419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int changes = 0; 14429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 14439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (width != o.width) { 14449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project width = o.width; 144540e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (height != o.height) { 14489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project height = o.height; 144940e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (x != o.x) { 14529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project x = o.x; 14539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= LAYOUT_CHANGED; 14549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (y != o.y) { 14569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project y = o.y; 14579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= LAYOUT_CHANGED; 14589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (horizontalWeight != o.horizontalWeight) { 14609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalWeight = o.horizontalWeight; 146140e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (verticalWeight != o.verticalWeight) { 14649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalWeight = o.verticalWeight; 146540e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (horizontalMargin != o.horizontalMargin) { 14689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project horizontalMargin = o.horizontalMargin; 146940e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (verticalMargin != o.verticalMargin) { 14729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project verticalMargin = o.verticalMargin; 147340e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (type != o.type) { 14769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project type = o.type; 14779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= TYPE_CHANGED; 14789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (flags != o.flags) { 14809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project flags = o.flags; 148140e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= FLAGS_CHANGED; 14829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14835d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn if (privateFlags != o.privateFlags) { 14845d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn privateFlags = o.privateFlags; 14855d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn changes |= PRIVATE_FLAGS_CHANGED; 14865d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn } 14879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (softInputMode != o.softInputMode) { 14889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project softInputMode = o.softInputMode; 14899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= SOFT_INPUT_MODE_CHANGED; 14909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (gravity != o.gravity) { 14929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project gravity = o.gravity; 149340e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= LAYOUT_CHANGED; 14949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (format != o.format) { 14969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project format = o.format; 149740e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= FORMAT_CHANGED; 14989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (windowAnimations != o.windowAnimations) { 15009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project windowAnimations = o.windowAnimations; 15019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= ANIMATION_CHANGED; 15029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (token == null) { 15049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // NOTE: token only copied if the recipient doesn't 15059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // already have one. 15069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project token = o.token; 15079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (packageName == null) { 15099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // NOTE: packageName only copied if the recipient doesn't 15109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // already have one. 15119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project packageName = o.packageName; 15129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mTitle.equals(o.mTitle)) { 15149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mTitle = o.mTitle; 15159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= TITLE_CHANGED; 15169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (alpha != o.alpha) { 15189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project alpha = o.alpha; 15199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= ALPHA_CHANGED; 15209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (dimAmount != o.dimAmount) { 15229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dimAmount = o.dimAmount; 15239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= DIM_AMOUNT_CHANGED; 15249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenBrightness != o.screenBrightness) { 15269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenBrightness = o.screenBrightness; 15279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project changes |= SCREEN_BRIGHTNESS_CHANGED; 15289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1529fb73f79340375013225618a5d87f46b958f698efMike Lockwood if (buttonBrightness != o.buttonBrightness) { 1530fb73f79340375013225618a5d87f46b958f698efMike Lockwood buttonBrightness = o.buttonBrightness; 1531fb73f79340375013225618a5d87f46b958f698efMike Lockwood changes |= BUTTON_BRIGHTNESS_CHANGED; 1532fb73f79340375013225618a5d87f46b958f698efMike Lockwood } 15339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenOrientation != o.screenOrientation) { 15359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project screenOrientation = o.screenOrientation; 153640e0383dce630ed9b2b1aa0e497709b89dfab6efChet Haase changes |= SCREEN_ORIENTATION_CHANGED; 15379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1538529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy 153914782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato if (systemUiVisibility != o.systemUiVisibility 154014782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato || subtreeSystemUiVisibility != o.subtreeSystemUiVisibility) { 1541664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato systemUiVisibility = o.systemUiVisibility; 154214782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato subtreeSystemUiVisibility = o.subtreeSystemUiVisibility; 1543664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato changes |= SYSTEM_UI_VISIBILITY_CHANGED; 1544664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1545664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1546664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (hasSystemUiListeners != o.hasSystemUiListeners) { 1547664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato hasSystemUiListeners = o.hasSystemUiListeners; 1548664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato changes |= SYSTEM_UI_LISTENER_CHANGED; 1549664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1550664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato 1551474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown if (inputFeatures != o.inputFeatures) { 1552474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown inputFeatures = o.inputFeatures; 1553474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown changes |= INPUT_FEATURES_CHANGED; 1554474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown } 1555474dcb5c3ddff737c4ac9fc44a1f7be569605e5fJeff Brown 15561e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown if (userActivityTimeout != o.userActivityTimeout) { 15571e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown userActivityTimeout = o.userActivityTimeout; 15581e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown changes |= USER_ACTIVITY_TIMEOUT_CHANGED; 15591e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown } 15601e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown 15619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return changes; 15629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 15659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String debug(String output) { 15669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project output += "Contents of " + this + ":"; 15679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", output); 15689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project output = super.debug(""); 15699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", output); 15709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", ""); 15719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.d("Debug", "WindowManager.LayoutParams={title=" + mTitle + "}"); 15729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return ""; 15739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 15759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 15769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String toString() { 15779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project StringBuilder sb = new StringBuilder(256); 15789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append("WM.LayoutParams{"); 15799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append("("); 15809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(x); 15819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(','); 15829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(y); 15839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(")("); 1584980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy sb.append((width== MATCH_PARENT ?"fill":(width==WRAP_CONTENT?"wrap":width))); 15859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append('x'); 1586980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy sb.append((height== MATCH_PARENT ?"fill":(height==WRAP_CONTENT?"wrap":height))); 15879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(")"); 15888eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (horizontalMargin != 0) { 15898eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" hm="); 15908eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(horizontalMargin); 15918eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 15928eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (verticalMargin != 0) { 15938eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" vm="); 15948eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(verticalMargin); 15959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 15969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (gravity != 0) { 15979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" gr=#"); 15989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(gravity)); 15999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16008eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (softInputMode != 0) { 16018eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" sim=#"); 16028eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(Integer.toHexString(softInputMode)); 16038eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 16049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" ty="); 16059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(type); 16069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" fl=#"); 16079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(flags)); 16085d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn if (privateFlags != 0) { 16095d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn sb.append(" pfl=0x").append(Integer.toHexString(privateFlags)); 16105d927c2d8e832fcfcb0154c8741f896001141ef4Dianne Hackborn } 1611a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn if (format != PixelFormat.OPAQUE) { 1612a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(" fmt="); 1613a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(format); 1614a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn } 16159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (windowAnimations != 0) { 16169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" wanim=0x"); 16179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(Integer.toHexString(windowAnimations)); 16189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (screenOrientation != ActivityInfo.SCREEN_ORIENTATION_UNSPECIFIED) { 16209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(" or="); 16219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append(screenOrientation); 16229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16238eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (alpha != 1.0f) { 16248eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" alpha="); 16258eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(alpha); 16268eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 16278eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (screenBrightness != BRIGHTNESS_OVERRIDE_NONE) { 16288eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" sbrt="); 16298eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(screenBrightness); 16308eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 16318eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn if (buttonBrightness != BRIGHTNESS_OVERRIDE_NONE) { 16328eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(" bbrt="); 16338eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn sb.append(buttonBrightness); 16348eb2e244f9b14d946ee587d0b673b866865026c0Dianne Hackborn } 16355a2b91dc14e4c92e91c6abcc795f54ac98ee5866Mitsuru Oshima if ((flags & FLAG_COMPATIBLE_WINDOW) != 0) { 16365a2b91dc14e4c92e91c6abcc795f54ac98ee5866Mitsuru Oshima sb.append(" compatible=true"); 16375a2b91dc14e4c92e91c6abcc795f54ac98ee5866Mitsuru Oshima } 1638664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (systemUiVisibility != 0) { 1639664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(" sysui=0x"); 1640664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(Integer.toHexString(systemUiVisibility)); 1641664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 164214782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato if (subtreeSystemUiVisibility != 0) { 164314782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato sb.append(" vsysui=0x"); 164414782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato sb.append(Integer.toHexString(subtreeSystemUiVisibility)); 164514782f705e94d4e563a48efc85fd25129fd38a7dJoe Onorato } 1646664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato if (hasSystemUiListeners) { 1647664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(" sysuil="); 1648664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato sb.append(hasSystemUiListeners); 1649664644d9e012aa2a28ac96f305b1ce6499ec8806Joe Onorato } 1650a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn if (inputFeatures != 0) { 1651a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn sb.append(" if=0x").append(Integer.toHexString(inputFeatures)); 1652a44abeb125a0c8a8e5a065f868d316e41354286aDianne Hackborn } 16531e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown if (userActivityTimeout >= 0) { 16541e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown sb.append(" userActivityTimeout=").append(userActivityTimeout); 16551e3b98d47df596d0c4eadbdf60143709f8465b28Jeff Brown } 16569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append('}'); 16579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return sb.toString(); 16589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 16598d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima 16603d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima /** 16613d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima * Scale the layout params' coordinates and size. 166264f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima * @hide 1663e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 166464f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima public void scale(float scale) { 166561324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima x = (int) (x * scale + 0.5f); 166661324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima y = (int) (y * scale + 0.5f); 1667e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (width > 0) { 166861324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima width = (int) (width * scale + 0.5f); 1669e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima } 1670e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (height > 0) { 167161324e58c549670c015010d0be14c6af76e3e9f7Mitsuru Oshima height = (int) (height * scale + 0.5f); 16728d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima } 16738d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima } 16748d112675879a2b83197d3b4ae4fb623abd1a1ec3Mitsuru Oshima 16753d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima /** 1676e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * Backup the layout parameters used in compatibility mode. 1677e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * @see LayoutParams#restore() 1678e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 1679e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima void backup() { 1680e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima int[] backup = mCompatibilityParamsBackup; 1681e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (backup == null) { 168264f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima // we backup 4 elements, x, y, width, height 168364f59342d41849bd365cb43fad7505d5e3daa417Mitsuru Oshima backup = mCompatibilityParamsBackup = new int[4]; 16843d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 1685e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[0] = x; 1686e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[1] = y; 1687e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[2] = width; 1688e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima backup[3] = height; 1689e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima } 1690e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima 1691e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima /** 1692e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * Restore the layout params' coordinates, size and gravity 1693e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima * @see LayoutParams#backup() 1694e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima */ 1695e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima void restore() { 1696e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima int[] backup = mCompatibilityParamsBackup; 1697e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima if (backup != null) { 1698e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima x = backup[0]; 1699e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima y = backup[1]; 1700e5fb328825995aa33b5b7ecf8b5bee2b17f81715Mitsuru Oshima width = backup[2]; 17013d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima height = backup[3]; 17023d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 17033d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima } 17043d91492d694cf00474fec792134e496be6ee0313Mitsuru Oshima 17059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private CharSequence mTitle = ""; 17069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 17079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1708