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 199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Context; 209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.res.Configuration; 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.res.TypedArray; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.PixelFormat; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.drawable.Drawable; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.Uri; 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Bundle; 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.IBinder; 279622e20486955e3a3c2f45c61b23650fb35e6559Romain Guyimport android.os.SystemProperties; 2875986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganovimport android.view.accessibility.AccessibilityEvent; 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Abstract base class for a top-level window look and behavior policy. An 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * instance of this class should be used as the top-level view added to the 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window manager. It provides standard UI policies such as a background, title 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * area, default key processing, etc. 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>The only existing implementation of this abstract class is 379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * android.policy.PhoneWindow, which you should instantiate when needing a 389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window. Eventually that class will be refactored and a factory method 399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * added for creating Window instances without knowing about a particular 409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * implementation. 419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic abstract class Window { 439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for the "options panel" feature. This is enabled by default. */ 449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_OPTIONS_PANEL = 0; 459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for the "no title" feature, turning off the title at the top 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the screen. */ 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_NO_TITLE = 1; 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for the progress indicator feature */ 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_PROGRESS = 2; 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for having an icon on the left side of the title bar */ 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_LEFT_ICON = 3; 529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for having an icon on the right side of the title bar */ 539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_RIGHT_ICON = 4; 549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for indeterminate progress */ 559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_INDETERMINATE_PROGRESS = 5; 569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for the context menu. This is enabled by default. */ 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_CONTEXT_MENU = 6; 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for custom title. You cannot combine this feature with other title features. */ 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int FEATURE_CUSTOM_TITLE = 7; 6033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell /** 6133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * Flag for enabling the Action Bar. 6233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * This is enabled by default for some devices. The Action Bar 6333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * replaces the title bar and provides an alternate location 6433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * for an on-screen menu button on some devices. 6533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell */ 665d27977f9da482627ceb19317a2cd70467aff046Adam Powell public static final int FEATURE_ACTION_BAR = 8; 675d27977f9da482627ceb19317a2cd70467aff046Adam Powell /** 686b336f835d637853800b94689375a03f337139a4Adam Powell * Flag for requesting an Action Bar that overlays window content. 696b336f835d637853800b94689375a03f337139a4Adam Powell * Normally an Action Bar will sit in the space above window content, but if this 706b336f835d637853800b94689375a03f337139a4Adam Powell * feature is requested along with {@link #FEATURE_ACTION_BAR} it will be layered over 716b336f835d637853800b94689375a03f337139a4Adam Powell * the window content itself. This is useful if you would like your app to have more control 726b336f835d637853800b94689375a03f337139a4Adam Powell * over how the Action Bar is displayed, such as letting application content scroll beneath 736b336f835d637853800b94689375a03f337139a4Adam Powell * an Action Bar with a transparent background or otherwise displaying a transparent/translucent 746b336f835d637853800b94689375a03f337139a4Adam Powell * Action Bar over application content. 753a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * 763a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * <p>This mode is especially useful with {@link View#SYSTEM_UI_FLAG_FULLSCREEN 773a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * View.SYSTEM_UI_FLAG_FULLSCREEN}, which allows you to seamlessly hide the 783a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * action bar in conjunction with other screen decorations. 793a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * 803a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * <p>As of {@link android.os.Build.VERSION_CODES#JELLY_BEAN}, when an 813a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * ActionBar is in this mode it will adjust the insets provided to 823a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * {@link View#fitSystemWindows(android.graphics.Rect) View.fitSystemWindows(Rect)} 833a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * to include the content covered by the action bar, so you can do layout within 843a3a6cfd8ec12208ca75c0d0d871d19d76c34194Dianne Hackborn * that space. 856b336f835d637853800b94689375a03f337139a4Adam Powell */ 866b336f835d637853800b94689375a03f337139a4Adam Powell public static final int FEATURE_ACTION_BAR_OVERLAY = 9; 876b336f835d637853800b94689375a03f337139a4Adam Powell /** 885d27977f9da482627ceb19317a2cd70467aff046Adam Powell * Flag for specifying the behavior of action modes when an Action Bar is not present. 895d27977f9da482627ceb19317a2cd70467aff046Adam Powell * If overlay is enabled, the action mode UI will be allowed to cover existing window content. 905d27977f9da482627ceb19317a2cd70467aff046Adam Powell */ 916b336f835d637853800b94689375a03f337139a4Adam Powell public static final int FEATURE_ACTION_MODE_OVERLAY = 10; 924b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell 934b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell /** 944b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell * Max value used as a feature ID 954b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell * @hide 964b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell */ 974b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell public static final int FEATURE_MAX = FEATURE_ACTION_MODE_OVERLAY; 984b6d93fd0485b46a3a15a71516d39b4f72d9b3dbAdam Powell 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for setting the progress bar's visibility to VISIBLE */ 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_VISIBILITY_ON = -1; 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for setting the progress bar's visibility to GONE */ 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_VISIBILITY_OFF = -2; 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for setting the progress bar's indeterminate mode on */ 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_INDETERMINATE_ON = -3; 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Flag for setting the progress bar's indeterminate mode off */ 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_INDETERMINATE_OFF = -4; 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Starting value for the (primary) progress */ 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_START = 0; 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Ending value for the (primary) progress */ 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_END = 10000; 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Lowest possible value for the secondary progress */ 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_SECONDARY_START = 20000; 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** Highest possible value for the secondary progress */ 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int PROGRESS_SECONDARY_END = 30000; 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** The default features enabled */ 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @SuppressWarnings({"PointlessBitwiseExpression"}) 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected static final int DEFAULT_FEATURES = (1 << FEATURE_OPTIONS_PANEL) | 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project (1 << FEATURE_CONTEXT_MENU); 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The ID that the main layout in the XML layout file should have. 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ID_ANDROID_CONTENT = com.android.internal.R.id.content; 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 126d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown private static final String PROPERTY_HARDWARE_UI = "persist.sys.ui.hw"; 127d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private final Context mContext; 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private TypedArray mWindowStyle; 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private Callback mCallback; 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private WindowManager mWindowManager; 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private IBinder mAppToken; 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private String mAppName; 135d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown private boolean mHardwareAccelerated; 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private Window mContainer; 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private Window mActiveChild; 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean mIsActive = false; 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean mHasChildren = false; 140cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn private boolean mCloseOnTouchOutside = false; 141cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn private boolean mSetCloseOnTouchOutside = false; 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private int mForcedWindowFlags = 0; 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private int mFeatures = DEFAULT_FEATURES; 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private int mLocalFeatures = DEFAULT_FEATURES; 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean mHaveWindowFormat = false; 148661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn private boolean mHaveDimAmount = false; 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private int mDefaultWindowFormat = PixelFormat.OPAQUE; 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean mHasSoftInputMode = false; 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 153291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn private boolean mDestroyed; 154291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // The current window attributes. 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private final WindowManager.LayoutParams mWindowAttributes = 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project new WindowManager.LayoutParams(); 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * API from a Window back to its caller. This allows the client to 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * intercept key dispatching, panels and menus, etc. 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public interface Callback { 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called to process key events. At the very least your 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * implementation must call 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.view.Window#superDispatchKeyEvent} to do the 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * standard key processing. 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param event The key event. 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return boolean Return true if this event was consumed. 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean dispatchKeyEvent(KeyEvent event); 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 17764da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * Called to process a key shortcut event. 17864da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * At the very least your implementation must call 17964da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * {@link android.view.Window#superDispatchKeyShortcutEvent} to do the 18064da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * standard key shortcut processing. 18164da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * 18264da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * @param event The key shortcut event. 18364da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * @return True if this event was consumed. 18464da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown */ 18564da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown public boolean dispatchKeyShortcutEvent(KeyEvent event); 18664da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown 18764da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown /** 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called to process touch screen events. At the very least your 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * implementation must call 1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.view.Window#superDispatchTouchEvent} to do the 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * standard touch screen processing. 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param event The touch screen event. 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return boolean Return true if this event was consumed. 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean dispatchTouchEvent(MotionEvent event); 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called to process trackball events. At the very least your 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * implementation must call 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.view.Window#superDispatchTrackballEvent} to do the 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * standard trackball processing. 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param event The trackball event. 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return boolean Return true if this event was consumed. 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean dispatchTrackballEvent(MotionEvent event); 21075986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov 21175986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov /** 212cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * Called to process generic motion events. At the very least your 213cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * implementation must call 214cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * {@link android.view.Window#superDispatchGenericMotionEvent} to do the 215cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * standard processing. 216cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * 217cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * @param event The generic motion event. 218cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * 219cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * @return boolean Return true if this event was consumed. 220cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown */ 221cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown public boolean dispatchGenericMotionEvent(MotionEvent event); 222cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown 223cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown /** 22475986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * Called to process population of {@link AccessibilityEvent}s. 22575986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * 22675986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * @param event The event. 22775986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * 22875986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * @return boolean Return true if event population was completed. 22975986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov */ 23075986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov public boolean dispatchPopulateAccessibilityEvent(AccessibilityEvent event); 23175986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Instantiate the view to display in the panel for 'featureId'. 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You can return null, in which case the default content (typically 2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * a menu) will be created for you. 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId Which panel is being created. 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return view The top-level view to place in the panel. 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #onPreparePanel 2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public View onCreatePanelView(int featureId); 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Initialize the contents of the menu for panel 'featureId'. This is 2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * called if onCreatePanelView() returns null, giving you a standard 2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * menu in which you can place your items. It is only called once for 2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the panel, the first time it is shown. 2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>You can safely hold on to <var>menu</var> (and any items created 2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * from it), making modifications to it as desired, until the next 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * time onCreatePanelMenu() is called for this feature. 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The panel being created. 2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param menu The menu inside the panel. 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return boolean You must return true for the panel to be displayed; 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if you return false it will not be shown. 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean onCreatePanelMenu(int featureId, Menu menu); 2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Prepare a panel to be displayed. This is called right before the 2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * panel window is shown, every time it is shown. 2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The panel that is being displayed. 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The View that was returned by onCreatePanelView(). 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param menu If onCreatePanelView() returned null, this is the Menu 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * being displayed in the panel. 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return boolean You must return true for the panel to be displayed; 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if you return false it will not be shown. 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #onCreatePanelView 2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean onPreparePanel(int featureId, View view, Menu menu); 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called when a panel's menu is opened by the user. This may also be 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * called when the menu is changing from one type to another (for 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * example, from the icon menu to the expanded menu). 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The panel that the menu is in. 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param menu The menu that is opened. 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Return true to allow the menu to open, or false to prevent 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the menu from opening. 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean onMenuOpened(int featureId, Menu menu); 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called when a panel's menu item has been selected by the user. 2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The panel that the menu is in. 2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param item The menu item that was selected. 2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return boolean Return true to finish processing of selection, or 2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * false to perform the normal menu handling (calling its 2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Runnable or sending a Message to its target Handler). 3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean onMenuItemSelected(int featureId, MenuItem item); 3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This is called whenever the current window attributes change. 3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void onWindowAttributesChanged(WindowManager.LayoutParams attrs); 3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This hook is called whenever the content view of the screen changes 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * (due to a call to 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link Window#setContentView(View, android.view.ViewGroup.LayoutParams) 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window.setContentView} or 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link Window#addContentView(View, android.view.ViewGroup.LayoutParams) 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window.addContentView}). 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void onContentChanged(); 3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3203be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * This hook is called whenever the window focus changes. See 3213be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * {@link View#onWindowFocusChanged(boolean) 3223be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * View.onWindowFocusChanged(boolean)} for more information. 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param hasFocus Whether the window now has focus. 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void onWindowFocusChanged(boolean hasFocus); 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3293be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * Called when the window has been attached to the window manager. 3303be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * See {@link View#onAttachedToWindow() View.onAttachedToWindow()} 3313be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * for more information. 3323be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn */ 3333be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn public void onAttachedToWindow(); 3343be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn 3353be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn /** 3363be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * Called when the window has been attached to the window manager. 3373be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * See {@link View#onDetachedFromWindow() View.onDetachedFromWindow()} 3383be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn * for more information. 3393be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn */ 3403be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn public void onDetachedFromWindow(); 3413be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn 3423be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn /** 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called when a panel is being closed. If another logical subsequent 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * panel is being opened (and this panel is being closed to make room for the subsequent 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * panel), this method will NOT be called. 3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The panel that is being displayed. 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param menu If onCreatePanelView() returned null, this is the Menu 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * being displayed in the panel. 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void onPanelClosed(int featureId, Menu menu); 3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Called when the user signals the desire to start a search. 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return true if search launched, false if activity refuses (blocks) 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.app.Activity#onSearchRequested() 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean onSearchRequested(); 3616e34636749217654f43221885afb7a29bb5ca96aAdam Powell 3626e34636749217654f43221885afb7a29bb5ca96aAdam Powell /** 363debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * Called when an action mode is being started for this window. Gives the 364debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * callback an opportunity to handle the action mode in its own unique and 365debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * beautiful way. If this method returns null the system can choose a way 366debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * to present the mode or choose not to start the mode at all. 3676e34636749217654f43221885afb7a29bb5ca96aAdam Powell * 3686e34636749217654f43221885afb7a29bb5ca96aAdam Powell * @param callback Callback to control the lifecycle of this action mode 369debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * @return The ActionMode that was started, or null if the system should present it 3706e34636749217654f43221885afb7a29bb5ca96aAdam Powell */ 371debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell public ActionMode onWindowStartingActionMode(ActionMode.Callback callback); 372debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell 373debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell /** 374debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * Called when an action mode has been started. The appropriate mode callback 375debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * method will have already been invoked. 376debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * 377debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * @param mode The new mode that has just been started. 378debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell */ 379debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell public void onActionModeStarted(ActionMode mode); 380debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell 381debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell /** 382debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * Called when an action mode has been finished. The appropriate mode callback 383debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * method will have already been invoked. 384debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * 385debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell * @param mode The mode that was just finished. 386debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell */ 387debf3bed9ea913ac55c80e1f9f7f33217054a943Adam Powell public void onActionModeFinished(ActionMode mode); 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public Window(Context context) { 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mContext = context; 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the Context this window policy is running in, for retrieving 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * resources and other information. 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Context The Context that was supplied to the constructor. 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final Context getContext() { 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mContext; 4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the {@link android.R.styleable#Window} attributes from this 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window's theme. 4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final TypedArray getWindowStyle() { 4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project synchronized (this) { 4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mWindowStyle == null) { 4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mWindowStyle = mContext.obtainStyledAttributes( 4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project com.android.internal.R.styleable.Window); 4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mWindowStyle; 4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the container for this window. If not set, the DecorWindow 4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * operates as a top-level window; otherwise, it negotiates with the 4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * container to display itself appropriately. 4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param container The desired containing Window. 4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setContainer(Window container) { 4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mContainer = container; 4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (container != null) { 4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Embedded screens never have a title. 4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mFeatures |= 1<<FEATURE_NO_TITLE; 4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mLocalFeatures |= 1<<FEATURE_NO_TITLE; 4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project container.mHasChildren = true; 4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the container for this Window. 4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Window The containing window, or null if this is a 4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * top-level window. 4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final Window getContainer() { 4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mContainer; 4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final boolean hasChildren() { 4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mHasChildren; 4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 449291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn /** @hide */ 450291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn public final void destroy() { 451291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn mDestroyed = true; 452291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn } 453291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn 454291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn /** @hide */ 455291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn public final boolean isDestroyed() { 456291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn return mDestroyed; 457291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn } 458291905e34a7f0ae03c68fb2c1b8c34b92d447fbfDianne Hackborn 4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the window manager for use by this Window to, for example, 4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * display panels. This is <em>not</em> used for displaying the 4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window itself -- that must be done by the client. 4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 46498365d7663cbd82979a5700faf0050220b01084dJeff Brown * @param wm The window manager for adding new windows. 4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 466529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy public void setWindowManager(WindowManager wm, IBinder appToken, String appName) { 467529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy setWindowManager(wm, appToken, appName, false); 468529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy } 469529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy 470529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy /** 471529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy * Set the window manager for use by this Window to, for example, 472529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy * display panels. This is <em>not</em> used for displaying the 473529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy * Window itself -- that must be done by the client. 474529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy * 47598365d7663cbd82979a5700faf0050220b01084dJeff Brown * @param wm The window manager for adding new windows. 476529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy */ 477529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy public void setWindowManager(WindowManager wm, IBinder appToken, String appName, 478529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy boolean hardwareAccelerated) { 4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mAppToken = appToken; 4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mAppName = appName; 481d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown mHardwareAccelerated = hardwareAccelerated 482d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown || SystemProperties.getBoolean(PROPERTY_HARDWARE_UI, false); 4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (wm == null) { 48498365d7663cbd82979a5700faf0050220b01084dJeff Brown wm = (WindowManager)mContext.getSystemService(Context.WINDOW_SERVICE); 4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 48698365d7663cbd82979a5700faf0050220b01084dJeff Brown mWindowManager = ((WindowManagerImpl)wm).createLocalWindowManager(this); 4875fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn } 4885fd2169eabd77e6bfafaf456e58051a3bafb2bcaDianne Hackborn 489d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown void adjustLayoutParamsForSubWindow(WindowManager.LayoutParams wp) { 490d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown CharSequence curTitle = wp.getTitle(); 491d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (wp.type >= WindowManager.LayoutParams.FIRST_SUB_WINDOW && 492d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.type <= WindowManager.LayoutParams.LAST_SUB_WINDOW) { 493d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (wp.token == null) { 494d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown View decor = peekDecorView(); 495d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (decor != null) { 496d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.token = decor.getWindowToken(); 4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 498d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } 499d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (curTitle == null || curTitle.length() == 0) { 500d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown String title; 501d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_MEDIA) { 502d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title="Media"; 503d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_MEDIA_OVERLAY) { 504d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title="MediaOvr"; 505d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_PANEL) { 506d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title="Panel"; 507d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_SUB_PANEL) { 508d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title="SubPanel"; 509d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_ATTACHED_DIALOG) { 510d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title="AtchDlg"; 511d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } else { 512d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title=Integer.toString(wp.type); 5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 514d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (mAppName != null) { 515d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown title += ":" + mAppName; 5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 517d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.setTitle(title); 5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 519d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } else { 520d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (wp.token == null) { 521d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.token = mContainer == null ? mAppToken : mContainer.mAppToken; 522529b60a3b16ac3dff24f2403d760ab8ebc9670ffRomain Guy } 523d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if ((curTitle == null || curTitle.length() == 0) 524d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown && mAppName != null) { 525d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.setTitle(mAppName); 526d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } 527d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } 528d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (wp.packageName == null) { 529d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.packageName = mContext.getPackageName(); 530d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown } 531d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown if (mHardwareAccelerated) { 532d32460c5b7bea7b06e345397fdbaca58d9732dcfJeff Brown wp.flags |= WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED; 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the window manager allowing this Window to display its own 5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * windows. 5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return WindowManager The ViewManager. 5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public WindowManager getWindowManager() { 5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mWindowManager; 5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the Callback interface for this window, used to intercept key 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * events and other dynamic operations in the window. 5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param callback The desired Callback interface. 5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setCallback(Callback callback) { 5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback = callback; 5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the current Callback interface for this window. 5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final Callback getCallback() { 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mCallback; 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 564dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn * Take ownership of this window's surface. The window's view hierarchy 565dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn * will no longer draw into the surface, though it will otherwise continue 566dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn * to operate (such as for receiving input events). The given SurfaceHolder 567dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn * callback will be used to tell you about state changes to the surface. 568dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn */ 569d76b67c340d1564abf8d14d976fdaf83bf2b3320Dianne Hackborn public abstract void takeSurface(SurfaceHolder.Callback2 callback); 570dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn 571dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn /** 5721e4b9f3936d6f357e89360293e05a0e16d5fa440Dianne Hackborn * Take ownership of this window's InputQueue. The window will no 5731e4b9f3936d6f357e89360293e05a0e16d5fa440Dianne Hackborn * longer read and dispatch input events from the queue; it is your 574a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn * responsibility to do so. 575a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn */ 5761e4b9f3936d6f357e89360293e05a0e16d5fa440Dianne Hackborn public abstract void takeInputQueue(InputQueue.Callback callback); 577a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn 578a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn /** 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return whether this window is being displayed with a floating style 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * (based on the {@link android.R.attr#windowIsFloating} attribute in 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the style/theme). 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Returns true if the window is configured to be displayed floating 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * on top of whatever is behind it. 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean isFloating(); 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the width and height layout parameters of the window. The default 590c91893511dc1b9e634648406c9ae61b15476e65dDianne Hackborn * for both of these is MATCH_PARENT; you can change them to WRAP_CONTENT 591c91893511dc1b9e634648406c9ae61b15476e65dDianne Hackborn * or an absolute value to make a window that is not full-screen. 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param width The desired layout width of the window. 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param height The desired layout height of the window. 595c91893511dc1b9e634648406c9ae61b15476e65dDianne Hackborn * 596c91893511dc1b9e634648406c9ae61b15476e65dDianne Hackborn * @see ViewGroup.LayoutParams#height 597c91893511dc1b9e634648406c9ae61b15476e65dDianne Hackborn * @see ViewGroup.LayoutParams#width 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 599c91893511dc1b9e634648406c9ae61b15476e65dDianne Hackborn public void setLayout(int width, int height) { 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.width = width; 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.height = height; 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the gravity of the window, as per the Gravity constants. This 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * controls how the window manager is positioned in the overall window; it 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is only useful when using WRAP_CONTENT for the layout width or height. 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param gravity The desired gravity constant. 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see Gravity 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setLayout 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setGravity(int gravity) 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project { 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.gravity = gravity; 6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the type of the window, as per the WindowManager.LayoutParams 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * types. 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param type The new window type (see WindowManager.LayoutParams). 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setType(int type) { 6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.type = type; 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the format of window, as per the PixelFormat types. This overrides 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the default format that is selected by the Window based on its 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window decorations. 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param format The new window format (see PixelFormat). Use 6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * PixelFormat.UNKNOWN to allow the Window to select 6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the format. 6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see PixelFormat 6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setFormat(int format) { 6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (format != PixelFormat.UNKNOWN) { 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.format = format; 6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mHaveWindowFormat = true; 6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.format = mDefaultWindowFormat; 6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mHaveWindowFormat = false; 6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Specify custom animations to use for the window, as per 6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams#windowAnimations 6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WindowManager.LayoutParams.windowAnimations}. Providing anything besides 6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 0 here will override the animations the window would 6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * normally retrieve from its theme. 6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setWindowAnimations(int resId) { 6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.windowAnimations = resId; 6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Specify an explicit soft input mode to use for the window, as per 6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams#softInputMode 6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WindowManager.LayoutParams.softInputMode}. Providing anything besides 6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * "unspecified" here will override the input mode the window would 6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * normally retrieve from its theme. 6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setSoftInputMode(int mode) { 6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mode != WindowManager.LayoutParams.SOFT_INPUT_STATE_UNSPECIFIED) { 6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.softInputMode = mode; 6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mHasSoftInputMode = true; 6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mHasSoftInputMode = false; 6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Convenience function to set the flag bits as specified in flags, as 7039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * per {@link #setFlags}. 7049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags The flag bits to be set. 7059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setFlags 706193fc075a2a19517c175a5760fc5e9f10d0f2e31Christopher Tate * @see #clearFlags 7079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void addFlags(int flags) { 7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setFlags(flags, flags); 7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Convenience function to clear the flag bits as specified in flags, as 7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * per {@link #setFlags}. 7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags The flag bits to be cleared. 7169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setFlags 717193fc075a2a19517c175a5760fc5e9f10d0f2e31Christopher Tate * @see #addFlags 7189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void clearFlags(int flags) { 7209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setFlags(0, flags); 7219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the flags of the window, as per the 7259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams WindowManager.LayoutParams} 7269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * flags. 7279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 7289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>Note that some flags must be set before the window decoration is 7299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * created (by the first call to 7309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)} or 7319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #getDecorView()}: 7329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams#FLAG_LAYOUT_IN_SCREEN} and 7339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link WindowManager.LayoutParams#FLAG_LAYOUT_INSET_DECOR}. These 7349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be set for you based on the {@link android.R.attr#windowIsFloating} 7359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * attribute. 7369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 7379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param flags The new window flags (see WindowManager.LayoutParams). 7389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param mask Which of the window flag bits to modify. 739193fc075a2a19517c175a5760fc5e9f10d0f2e31Christopher Tate * @see #addFlags 740193fc075a2a19517c175a5760fc5e9f10d0f2e31Christopher Tate * @see #clearFlags 7419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setFlags(int flags, int mask) { 7439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 7449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.flags = (attrs.flags&~mask) | (flags&mask); 74573ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn if ((mask&WindowManager.LayoutParams.FLAG_NEEDS_MENU_KEY) != 0) { 74673ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn attrs.privateFlags |= WindowManager.LayoutParams.PRIVATE_FLAG_SET_NEEDS_MENU_KEY; 74773ab6a49db2b834ce1d56c7a1164938b409ee6fcDianne Hackborn } 7489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mForcedWindowFlags |= mask; 7499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 7509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 7519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 755661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn * Set the amount of dim behind the window when using 756661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn * {@link WindowManager.LayoutParams#FLAG_DIM_BEHIND}. This overrides 757661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn * the default dim amount of that is selected by the Window based on 758661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn * its theme. 759661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn * 760661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn * @param amount The new dim amount, from 0 for no dim to 1 for full dim. 761661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn */ 762661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn public void setDimAmount(float amount) { 763661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn final WindowManager.LayoutParams attrs = getAttributes(); 764661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn attrs.dimAmount = amount; 765661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn mHaveDimAmount = true; 766661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn if (mCallback != null) { 767661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn mCallback.onWindowAttributesChanged(attrs); 768661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn } 769661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn } 770661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn 771661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn /** 7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Specify custom window attributes. <strong>PLEASE NOTE:</strong> the 7739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * layout params you give here should generally be from values previously 7749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * retrieved with {@link #getAttributes()}; you probably do not want to 7759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * blindly create and apply your own, since this will blow away any values 7769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set by the framework that you are not interested in. 7779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 7789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param a The new window attributes, which will completely override any 7799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * current values. 7809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setAttributes(WindowManager.LayoutParams a) { 7829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mWindowAttributes.copyFrom(a); 7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(mWindowAttributes); 7859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieve the current window attributes associated with this panel. 7909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 7919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return WindowManager.LayoutParams Either the existing window 7929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * attributes object, or a freshly created one if there is none. 7939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final WindowManager.LayoutParams getAttributes() { 7959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mWindowAttributes; 7969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the window flags that have been explicitly set by the client, 8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * so will not be modified by {@link #getDecorView}. 8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected final int getForcedWindowFlags() { 8039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mForcedWindowFlags; 8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Has the app specified their own soft input mode? 8089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 8099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected final boolean hasSoftInputMode() { 8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mHasSoftInputMode; 8119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 813cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn /** @hide */ 814cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn public void setCloseOnTouchOutside(boolean close) { 815cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn mCloseOnTouchOutside = close; 816cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn mSetCloseOnTouchOutside = true; 817cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn } 818cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn 819cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn /** @hide */ 820ef57575887bde74ef09e9f21aae6b02f9c8163c7Dianne Hackborn public void setCloseOnTouchOutsideIfNotSet(boolean close) { 821ef57575887bde74ef09e9f21aae6b02f9c8163c7Dianne Hackborn if (!mSetCloseOnTouchOutside) { 822ef57575887bde74ef09e9f21aae6b02f9c8163c7Dianne Hackborn mCloseOnTouchOutside = close; 823ef57575887bde74ef09e9f21aae6b02f9c8163c7Dianne Hackborn mSetCloseOnTouchOutside = true; 824ef57575887bde74ef09e9f21aae6b02f9c8163c7Dianne Hackborn } 825cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn } 826cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn 827cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn /** @hide */ 828cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn public abstract void alwaysReadCloseOnTouchAttr(); 829cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn 830cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn /** @hide */ 831cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn public boolean shouldCloseOnTouch(Context context, MotionEvent event) { 832cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn if (mCloseOnTouchOutside && event.getAction() == MotionEvent.ACTION_DOWN 833cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn && isOutOfBounds(context, event) && peekDecorView() != null) { 834cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn return true; 835cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn } 836cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn return false; 837cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn } 838cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn 839cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn private boolean isOutOfBounds(Context context, MotionEvent event) { 840cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn final int x = (int) event.getX(); 841cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn final int y = (int) event.getY(); 842cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn final int slop = ViewConfiguration.get(context).getScaledWindowTouchSlop(); 843cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn final View decorView = getDecorView(); 844cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn return (x < -slop) || (y < -slop) 845cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn || (x > (decorView.getWidth()+slop)) 846cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn || (y > (decorView.getHeight()+slop)); 847cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn } 848cfaf8878de83b6bb7a24aee3c240259f428e6e4aDianne Hackborn 8499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 8509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Enable extended screen features. This must be called before 8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * setContentView(). May be called as many times as desired as long as it 8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is before setContentView(). If not called, no extended features 8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be available. You can not turn off a feature once it is requested. 8549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You canot use other title features with {@link #FEATURE_CUSTOM_TITLE}. 8559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 8569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The desired features, defined as constants by Window. 8579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The features that are now set. 8589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 8599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean requestFeature(int featureId) { 8609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final int flag = 1<<featureId; 8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mFeatures |= flag; 8629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mLocalFeatures |= mContainer != null ? (flag&~mContainer.mFeatures) : flag; 8639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return (mFeatures&flag) != 0; 8649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 866f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell /** 867f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell * @hide Used internally to help resolve conflicting features. 868f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell */ 869f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell protected void removeFeature(int featureId) { 870f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell final int flag = 1<<featureId; 871f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell mFeatures &= ~flag; 872f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell mLocalFeatures &= ~(mContainer != null ? (flag&~mContainer.mFeatures) : flag); 873f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell } 874f4a6ec4e9398c1beb019e1c208272bf56401f925Adam Powell 8759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final void makeActive() { 8769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mContainer != null) { 8779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mContainer.mActiveChild != null) { 8789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mContainer.mActiveChild.mIsActive = false; 8799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mContainer.mActiveChild = this; 8819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mIsActive = true; 8839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project onActive(); 8849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final boolean isActive() 8879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project { 8889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mIsActive; 8899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 8929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Finds a view that was identified by the id attribute from the XML that 8939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * was processed in {@link android.app.Activity#onCreate}. This will 8949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * implicitly call {@link #getDecorView} for you, with all of the 8959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * associated side-effects. 8969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 8979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The view if found or null otherwise. 8989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 8999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public View findViewById(int id) { 9009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return getDecorView().findViewById(id); 9019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Convenience for 9059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)} 9069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to set the screen content from a layout resource. The resource will be 9079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * inflated, adding all top-level views to the screen. 9089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param layoutResID Resource ID to be inflated. 9109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setContentView(View, android.view.ViewGroup.LayoutParams) 9119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setContentView(int layoutResID); 9139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Convenience for 9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)} 9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * set the screen content to an explicit view. This view is placed 9189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * directly into the screen's view hierarchy. It can itself be a complex 9199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * view hierarhcy. 9209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The desired content to display. 9229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setContentView(View, android.view.ViewGroup.LayoutParams) 9239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setContentView(View view); 9259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the screen content to an explicit view. This view is placed 9289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * directly into the screen's view hierarchy. It can itself be a complex 9299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * view hierarchy. 9309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>Note that calling this function "locks in" various characteristics 9329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the window that can not, from this point forward, be changed: the 9339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * features that have been requested with {@link #requestFeature(int)}, 9349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and certain window flags as described in {@link #setFlags(int, int)}. 9359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The desired content to display. 9379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param params Layout parameters for the view. 9389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setContentView(View view, ViewGroup.LayoutParams params); 9409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Variation on 9439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)} 9449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to add an additional content view to the screen. Added after any existing 9459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * ones in the screen -- existing views are NOT removed. 9469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The desired content to display. 9489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param params Layout parameters for the view. 9499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void addContentView(View view, ViewGroup.LayoutParams params); 9519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the view in this Window that currently has focus, or null if 9549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * there are none. Note that this does not look in any containing 9559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window. 9569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return View The current View with focus or null. 9589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract View getCurrentFocus(); 9609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Quick access to the {@link LayoutInflater} instance that this Window 9639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * retrieved from its Context. 9649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return LayoutInflater The shared LayoutInflater. 9669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract LayoutInflater getLayoutInflater(); 9689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setTitle(CharSequence title); 9709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setTitleColor(int textColor); 9729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void openPanel(int featureId, KeyEvent event); 9749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void closePanel(int featureId); 9769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void togglePanel(int featureId, KeyEvent event); 9789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 979b31e84bc4513e46bac4be8f8d0513f78e360fb11Dianne Hackborn public abstract void invalidatePanelMenu(int featureId); 980b31e84bc4513e46bac4be8f8d0513f78e360fb11Dianne Hackborn 9819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean performPanelShortcut(int featureId, 9829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int keyCode, 9839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project KeyEvent event, 9849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int flags); 9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean performPanelIdentifierAction(int featureId, 9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int id, 9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int flags); 9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void closeAllPanels(); 9909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean performContextMenuIdentifierAction(int id, int flags); 9929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Should be called when the configuration is changed. 9959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param newConfig The new configuration. 9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void onConfigurationChanged(Configuration newConfig); 9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Change the background of this window to a Drawable resource. Setting the 10029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * background to null will make the window be opaque. To make the window 10039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * transparent, you can use an empty drawable (for instance a ColorDrawable 10049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * with the color 0 or the system drawable android:drawable/empty.) 10059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param resid The resource identifier of a drawable resource which will be 10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * installed as the new background. 10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setBackgroundDrawableResource(int resid) 10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project { 10119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setBackgroundDrawable(mContext.getResources().getDrawable(resid)); 10129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Change the background of this window to a custom Drawable. Setting the 10169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * background to null will make the window be opaque. To make the window 10179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * transparent, you can use an empty drawable (for instance a ColorDrawable 10189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * with the color 0 or the system drawable android:drawable/empty.) 10199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param drawable The new Drawable to use for this window's background. 10219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setBackgroundDrawable(Drawable drawable); 10239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the value for a drawable feature of this window, from a resource 10269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * identifier. You must have called requestFeauture(featureId) before 10279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * calling this function. 10289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.content.res.Resources#getDrawable(int) 10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The desired drawable feature to change, defined as a 10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * constant by Window. 10339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param resId Resource identifier of the desired image. 10349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setFeatureDrawableResource(int featureId, int resId); 10369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the value for a drawable feature of this window, from a URI. You 10399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * must have called requestFeature(featureId) before calling this 10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * function. 10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>The only URI currently supported is "content:", specifying an image 10439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * in a content provider. 10449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.widget.ImageView#setImageURI 10469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The desired drawable feature to change. Features are 10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * constants defined by Window. 10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param uri The desired URI. 10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setFeatureDrawableUri(int featureId, Uri uri); 10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set an explicit Drawable value for feature of this window. You must 10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * have called requestFeature(featureId) before calling this function. 10569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The desired drawable feature to change. 10589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Features are constants defined by Window. 10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param drawable A Drawable object to display. 10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setFeatureDrawable(int featureId, Drawable drawable); 10629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set a custom alpha value for the given drawale feature, controlling how 10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * much the background is visible through it. 10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The desired drawable feature to change. 10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Features are constants defined by Window. 10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param alpha The alpha amount, 0 is completely transparent and 255 is 10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * completely opaque. 10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setFeatureDrawableAlpha(int featureId, int alpha); 10739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the integer value for a feature. The range of the value depends on 10769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the feature being set. For FEATURE_PROGRESSS, it should go from 0 to 10779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10000. At 10000 the progress is complete and the indicator hidden. 10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param featureId The desired feature to change. 10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Features are constants defined by Window. 10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param value The value for the feature. The interpretation of this 10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * value is feature-specific. 10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setFeatureInt(int featureId, int value); 10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Request that key events come to this activity. Use this if your 10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * activity has no views with focus, but the activity still wants 10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * a chance to process key events. 10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void takeKeyEvents(boolean get); 10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Used by custom windows, such as Dialog, to pass the key press event 10959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * further down the view hierarchy. Application developers should 10969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not need to implement or call this. 10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean superDispatchKeyEvent(KeyEvent event); 11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 110264da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * Used by custom windows, such as Dialog, to pass the key shortcut press event 110364da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * further down the view hierarchy. Application developers should 110464da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * not need to implement or call this. 110564da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown * 110664da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown */ 110764da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown public abstract boolean superDispatchKeyShortcutEvent(KeyEvent event); 110864da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown 110964da12ab1f472e01325b6c6d094153ac110eaf7bJeff Brown /** 11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Used by custom windows, such as Dialog, to pass the touch screen event 11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * further down the view hierarchy. Application developers should 11129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not need to implement or call this. 11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean superDispatchTouchEvent(MotionEvent event); 11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Used by custom windows, such as Dialog, to pass the trackball event 11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * further down the view hierarchy. Application developers should 11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not need to implement or call this. 11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean superDispatchTrackballEvent(MotionEvent event); 11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1126cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * Used by custom windows, such as Dialog, to pass the generic motion event 1127cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * further down the view hierarchy. Application developers should 1128cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * not need to implement or call this. 1129cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown * 1130cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown */ 1131cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown public abstract boolean superDispatchGenericMotionEvent(MotionEvent event); 1132cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown 1133cb1404e45639d20439d7700b06d57ca1a1aad1faJeff Brown /** 11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieve the top-level window decor view (containing the standard 11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window frame/decorations and the client's content inside of that), which 11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * can be added as a window to the window manager. 11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p><em>Note that calling this function for the first time "locks in" 11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * various window characteristics as described in 11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)}.</em></p> 11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Returns the top-level window decor view. 11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract View getDecorView(); 11459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieve the current decor view, but only if it has already been created; 11489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * otherwise returns null. 11499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Returns the top-level window decor or null. 11519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #getDecorView 11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract View peekDecorView(); 11549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract Bundle saveHierarchyState(); 11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void restoreHierarchyState(Bundle savedInstanceState); 11589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected abstract void onActive(); 11609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the feature bits that are enabled. This is the set of features 11639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * that were given to requestFeature(), and are being handled by this 11649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window itself or its container. That is, it is the set of 11659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * requested features that you can actually use. 11669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>To do: add a public version of this API that allows you to check for 11689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * features by their feature ID. 11699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return int The feature bits. 11719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected final int getFeatures() 11739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project { 11749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mFeatures; 11759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 117633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell 117733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell /** 117833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * Query for the availability of a certain feature. 117933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * 118033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * @param feature The feature ID to check 118133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * @return true if the feature is enabled, false otherwise. 118233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell */ 118333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell public boolean hasFeature(int feature) { 118433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell return (getFeatures() & (1 << feature)) != 0; 118533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell } 11869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the feature bits that are being implemented by this Window. 11899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This is the set of features that were given to requestFeature(), and are 11909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * being handled by only this Window itself, not by its containers. 11919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return int The feature bits. 11939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected final int getLocalFeatures() 11959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project { 11969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mLocalFeatures; 11979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Set the default format of window, as per the PixelFormat types. This 12019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is the format that will be used unless the client specifies in explicit 12029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * format with setFormat(); 12039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 12049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param format The new window format (see PixelFormat). 12059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 12069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setFormat 12079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see PixelFormat 12089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected void setDefaultWindowFormat(int format) { 12109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDefaultWindowFormat = format; 12119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mHaveWindowFormat) { 12129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final WindowManager.LayoutParams attrs = getAttributes(); 12139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project attrs.format = format; 12149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mCallback != null) { 12159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mCallback.onWindowAttributesChanged(attrs); 12169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1220661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn /** @hide */ 1221661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn protected boolean haveDimAmount() { 1222661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn return mHaveDimAmount; 1223661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn } 1224661cd52e0e1d527132eb1cae604d3e64da7ec0cbDianne Hackborn 12259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setChildDrawable(int featureId, Drawable drawable); 12269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setChildInt(int featureId, int value); 12289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Is a keypress one of the defined shortcut keys for this window. 12319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param keyCode the key code from {@link android.view.KeyEvent} to check. 12329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param event the {@link android.view.KeyEvent} to use to help check. 12339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract boolean isShortcutKey(int keyCode, KeyEvent event); 12359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.app.Activity#setVolumeControlStream(int) 12389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setVolumeControlStream(int streamType); 12409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see android.app.Activity#getVolumeControlStream() 12439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract int getVolumeControlStream(); 1245269248d112e35fe8e9f0d5d11c96dcb2ac1118b0Adam Powell 1246269248d112e35fe8e9f0d5d11c96dcb2ac1118b0Adam Powell /** 1247269248d112e35fe8e9f0d5d11c96dcb2ac1118b0Adam Powell * Set extra options that will influence the UI for this window. 1248269248d112e35fe8e9f0d5d11c96dcb2ac1118b0Adam Powell * @param uiOptions Flags specifying extra options for this window. 1249269248d112e35fe8e9f0d5d11c96dcb2ac1118b0Adam Powell */ 1250269248d112e35fe8e9f0d5d11c96dcb2ac1118b0Adam Powell public void setUiOptions(int uiOptions) { } 1251e43fca99573291311f90b540d67833011d5fc6beAdam Powell 1252e43fca99573291311f90b540d67833011d5fc6beAdam Powell /** 1253e43fca99573291311f90b540d67833011d5fc6beAdam Powell * Set extra options that will influence the UI for this window. 1254e43fca99573291311f90b540d67833011d5fc6beAdam Powell * Only the bits filtered by mask will be modified. 1255e43fca99573291311f90b540d67833011d5fc6beAdam Powell * @param uiOptions Flags specifying extra options for this window. 1256e43fca99573291311f90b540d67833011d5fc6beAdam Powell * @param mask Flags specifying which options should be modified. Others will remain unchanged. 1257e43fca99573291311f90b540d67833011d5fc6beAdam Powell */ 1258e43fca99573291311f90b540d67833011d5fc6beAdam Powell public void setUiOptions(int uiOptions, int mask) { } 12599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1260