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;
2775986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganovimport android.view.accessibility.AccessibilityEvent;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Abstract base class for a top-level window look and behavior policy.  An
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * instance of this class should be used as the top-level view added to the
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * window manager. It provides standard UI policies such as a background, title
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * area, default key processing, etc.
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p>The only existing implementation of this abstract class is
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * android.policy.PhoneWindow, which you should instantiate when needing a
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Window.  Eventually that class will be refactored and a factory method
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * added for creating Window instances without knowing about a particular
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * implementation.
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic abstract class Window {
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for the "options panel" feature.  This is enabled by default. */
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_OPTIONS_PANEL = 0;
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for the "no title" feature, turning off the title at the top
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  of the screen. */
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_NO_TITLE = 1;
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for the progress indicator feature */
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_PROGRESS = 2;
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for having an icon on the left side of the title bar */
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_LEFT_ICON = 3;
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for having an icon on the right side of the title bar */
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_RIGHT_ICON = 4;
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for indeterminate progress */
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_INDETERMINATE_PROGRESS = 5;
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for the context menu.  This is enabled by default. */
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_CONTEXT_MENU = 6;
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for custom title. You cannot combine this feature with other title features. */
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FEATURE_CUSTOM_TITLE = 7;
595b4718ba8aeac969095b75c20fbe74ced0c04725Mike Reed    /** Flag for asking for an OpenGL enabled window.
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        All 2D graphics will be handled by OpenGL ES.
615b4718ba8aeac969095b75c20fbe74ced0c04725Mike Reed        @hide
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    */
635b4718ba8aeac969095b75c20fbe74ced0c04725Mike Reed    public static final int FEATURE_OPENGL = 8;
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for setting the progress bar's visibility to VISIBLE */
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_VISIBILITY_ON = -1;
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for setting the progress bar's visibility to GONE */
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_VISIBILITY_OFF = -2;
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for setting the progress bar's indeterminate mode on */
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_INDETERMINATE_ON = -3;
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Flag for setting the progress bar's indeterminate mode off */
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_INDETERMINATE_OFF = -4;
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Starting value for the (primary) progress */
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_START = 0;
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Ending value for the (primary) progress */
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_END = 10000;
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Lowest possible value for the secondary progress */
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_SECONDARY_START = 20000;
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Highest possible value for the secondary progress */
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROGRESS_SECONDARY_END = 30000;
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** The default features enabled */
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @SuppressWarnings({"PointlessBitwiseExpression"})
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected static final int DEFAULT_FEATURES = (1 << FEATURE_OPTIONS_PANEL) |
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            (1 << FEATURE_CONTEXT_MENU);
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The ID that the main layout in the XML layout file should have.
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int ID_ANDROID_CONTENT = com.android.internal.R.id.content;
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final Context mContext;
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private TypedArray mWindowStyle;
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Callback mCallback;
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private WindowManager mWindowManager;
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private IBinder mAppToken;
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private String mAppName;
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Window mContainer;
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Window mActiveChild;
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private boolean mIsActive = false;
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private boolean mHasChildren = false;
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private int mForcedWindowFlags = 0;
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private int mFeatures = DEFAULT_FEATURES;
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private int mLocalFeatures = DEFAULT_FEATURES;
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private boolean mHaveWindowFormat = false;
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private int mDefaultWindowFormat = PixelFormat.OPAQUE;
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private boolean mHasSoftInputMode = false;
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    // The current window attributes.
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final WindowManager.LayoutParams mWindowAttributes =
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        new WindowManager.LayoutParams();
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * API from a Window back to its caller.  This allows the client to
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * intercept key dispatching, panels and menus, etc.
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public interface Callback {
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called to process key events.  At the very least your
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * implementation must call
1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * {@link android.view.Window#superDispatchKeyEvent} to do the
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * standard key processing.
1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param event The key event.
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return boolean Return true if this event was consumed.
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean dispatchKeyEvent(KeyEvent event);
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called to process touch screen events.  At the very least your
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * implementation must call
1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * {@link android.view.Window#superDispatchTouchEvent} to do the
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * standard touch screen processing.
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param event The touch screen event.
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return boolean Return true if this event was consumed.
1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean dispatchTouchEvent(MotionEvent event);
1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called to process trackball events.  At the very least your
1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * implementation must call
1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * {@link android.view.Window#superDispatchTrackballEvent} to do the
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * standard trackball processing.
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param event The trackball event.
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return boolean Return true if this event was consumed.
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean dispatchTrackballEvent(MotionEvent event);
15675986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov
15775986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov        /**
15875986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov         * Called to process population of {@link AccessibilityEvent}s.
15975986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov         *
16075986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov         * @param event The event.
16175986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov         *
16275986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov         * @return boolean Return true if event population was completed.
16375986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov         */
16475986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov        public boolean dispatchPopulateAccessibilityEvent(AccessibilityEvent event);
16575986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Instantiate the view to display in the panel for 'featureId'.
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * You can return null, in which case the default content (typically
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * a menu) will be created for you.
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param featureId Which panel is being created.
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return view The top-level view to place in the panel.
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @see #onPreparePanel
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public View onCreatePanelView(int featureId);
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Initialize the contents of the menu for panel 'featureId'.  This is
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * called if onCreatePanelView() returns null, giving you a standard
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * menu in which you can place your items.  It is only called once for
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * the panel, the first time it is shown.
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * <p>You can safely hold on to <var>menu</var> (and any items created
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * from it), making modifications to it as desired, until the next
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * time onCreatePanelMenu() is called for this feature.
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param featureId The panel being created.
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param menu The menu inside the panel.
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return boolean You must return true for the panel to be displayed;
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *         if you return false it will not be shown.
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean onCreatePanelMenu(int featureId, Menu menu);
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Prepare a panel to be displayed.  This is called right before the
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * panel window is shown, every time it is shown.
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param featureId The panel that is being displayed.
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param view The View that was returned by onCreatePanelView().
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param menu If onCreatePanelView() returned null, this is the Menu
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *             being displayed in the panel.
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return boolean You must return true for the panel to be displayed;
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *         if you return false it will not be shown.
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @see #onCreatePanelView
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean onPreparePanel(int featureId, View view, Menu menu);
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called when a panel's menu is opened by the user. This may also be
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * called when the menu is changing from one type to another (for
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * example, from the icon menu to the expanded menu).
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param featureId The panel that the menu is in.
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param menu The menu that is opened.
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return Return true to allow the menu to open, or false to prevent
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *         the menu from opening.
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean onMenuOpened(int featureId, Menu menu);
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called when a panel's menu item has been selected by the user.
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param featureId The panel that the menu is in.
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param item The menu item that was selected.
2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return boolean Return true to finish processing of selection, or
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *         false to perform the normal menu handling (calling its
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *         Runnable or sending a Message to its target Handler).
2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean onMenuItemSelected(int featureId, MenuItem item);
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * This is called whenever the current window attributes change.
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void onWindowAttributesChanged(WindowManager.LayoutParams attrs);
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * This hook is called whenever the content view of the screen changes
2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * (due to a call to
2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * {@link Window#setContentView(View, android.view.ViewGroup.LayoutParams)
2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Window.setContentView} or
2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * {@link Window#addContentView(View, android.view.ViewGroup.LayoutParams)
2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Window.addContentView}).
2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void onContentChanged();
2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2543be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * This hook is called whenever the window focus changes.  See
2553be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * {@link View#onWindowFocusChanged(boolean)
2563be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * View.onWindowFocusChanged(boolean)} for more information.
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param hasFocus Whether the window now has focus.
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void onWindowFocusChanged(boolean hasFocus);
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2633be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * Called when the window has been attached to the window manager.
2643be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * See {@link View#onAttachedToWindow() View.onAttachedToWindow()}
2653be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * for more information.
2663be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         */
2673be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn        public void onAttachedToWindow();
2683be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn
2693be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn        /**
2703be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * Called when the window has been attached to the window manager.
2713be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * See {@link View#onDetachedFromWindow() View.onDetachedFromWindow()}
2723be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         * for more information.
2733be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn         */
2743be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn        public void onDetachedFromWindow();
2753be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn
2763be63c09309b21c01b535271625d4c39045690e5Dianne Hackborn        /**
2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called when a panel is being closed.  If another logical subsequent
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * panel is being opened (and this panel is being closed to make room for the subsequent
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * panel), this method will NOT be called.
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param featureId The panel that is being displayed.
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param menu If onCreatePanelView() returned null, this is the Menu
2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *            being displayed in the panel.
2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void onPanelClosed(int featureId, Menu menu);
2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Called when the user signals the desire to start a search.
2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return true if search launched, false if activity refuses (blocks)
2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @see android.app.Activity#onSearchRequested()
2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean onSearchRequested();
2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public Window(Context context) {
2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mContext = context;
2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the Context this window policy is running in, for retrieving
3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * resources and other information.
3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Context The Context that was supplied to the constructor.
3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final Context getContext() {
3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mContext;
3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the {@link android.R.styleable#Window} attributes from this
3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * window's theme.
3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final TypedArray getWindowStyle() {
3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        synchronized (this) {
3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (mWindowStyle == null) {
3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mWindowStyle = mContext.obtainStyledAttributes(
3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        com.android.internal.R.styleable.Window);
3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return mWindowStyle;
3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the container for this window.  If not set, the DecorWindow
3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * operates as a top-level window; otherwise, it negotiates with the
3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * container to display itself appropriately.
3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param container The desired containing Window.
3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setContainer(Window container) {
3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mContainer = container;
3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (container != null) {
3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Embedded screens never have a title.
3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mFeatures |= 1<<FEATURE_NO_TITLE;
3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mLocalFeatures |= 1<<FEATURE_NO_TITLE;
3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            container.mHasChildren = true;
3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the container for this Window.
3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Window The containing window, or null if this is a
3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         top-level window.
3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final Window getContainer() {
3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mContainer;
3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final boolean hasChildren() {
3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mHasChildren;
3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the window manager for use by this Window to, for example,
3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * display panels.  This is <em>not</em> used for displaying the
3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Window itself -- that must be done by the client.
3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param wm The ViewManager for adding new windows.
3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setWindowManager(WindowManager wm,
3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            IBinder appToken, String appName) {
3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mAppToken = appToken;
3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mAppName = appName;
3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (wm == null) {
3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            wm = WindowManagerImpl.getDefault();
3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mWindowManager = new LocalWindowManager(wm);
3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private class LocalWindowManager implements WindowManager {
3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        LocalWindowManager(WindowManager wm) {
3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mWindowManager = wm;
376ddd12535f095d8d056716c3290faf50ec52a538aMitsuru Oshima            mDefaultDisplay = mContext.getResources().getDefaultDisplay(
377ddd12535f095d8d056716c3290faf50ec52a538aMitsuru Oshima                    mWindowManager.getDefaultDisplay());
3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public final void addView(View view, ViewGroup.LayoutParams params) {
3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Let this throw an exception on a bad params.
3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            WindowManager.LayoutParams wp = (WindowManager.LayoutParams)params;
3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            CharSequence curTitle = wp.getTitle();
3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (wp.type >= WindowManager.LayoutParams.FIRST_SUB_WINDOW &&
3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                wp.type <= WindowManager.LayoutParams.LAST_SUB_WINDOW) {
3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (wp.token == null) {
3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    View decor = peekDecorView();
3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    if (decor != null) {
3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        wp.token = decor.getWindowToken();
3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    }
3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (curTitle == null || curTitle.length() == 0) {
3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    String title;
3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_MEDIA) {
3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        title="Media";
396c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn                    } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_MEDIA_OVERLAY) {
397c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn                        title="MediaOvr";
3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_PANEL) {
3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        title="Panel";
400c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn                    } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_SUB_PANEL) {
401c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn                        title="SubPanel";
402c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn                    } else if (wp.type == WindowManager.LayoutParams.TYPE_APPLICATION_ATTACHED_DIALOG) {
403c4d5d02667af6989a3121072871f6a4b1e68b594Dianne Hackborn                        title="AtchDlg";
4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    } else {
4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        title=Integer.toString(wp.type);
4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    }
4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    if (mAppName != null) {
4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        title += ":" + mAppName;
4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    }
4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    wp.setTitle(title);
4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            } else {
4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (wp.token == null) {
4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    wp.token = mContainer == null ? mAppToken : mContainer.mAppToken;
4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if ((curTitle == null || curTitle.length() == 0)
4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        && mAppName != null) {
4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    wp.setTitle(mAppName);
4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project           }
4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (wp.packageName == null) {
4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                wp.packageName = mContext.getPackageName();
4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mWindowManager.addView(view, params);
4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void updateViewLayout(View view, ViewGroup.LayoutParams params) {
4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mWindowManager.updateViewLayout(view, params);
4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public final void removeView(View view) {
4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mWindowManager.removeView(view);
4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public final void removeViewImmediate(View view) {
4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mWindowManager.removeViewImmediate(view);
4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public Display getDefaultDisplay() {
440ddd12535f095d8d056716c3290faf50ec52a538aMitsuru Oshima            return mDefaultDisplay;
4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
443ddd12535f095d8d056716c3290faf50ec52a538aMitsuru Oshima        private final WindowManager mWindowManager;
444ddd12535f095d8d056716c3290faf50ec52a538aMitsuru Oshima
445ddd12535f095d8d056716c3290faf50ec52a538aMitsuru Oshima        private final Display mDefaultDisplay;
4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the window manager allowing this Window to display its own
4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * windows.
4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return WindowManager The ViewManager.
4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public WindowManager getWindowManager() {
4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mWindowManager;
4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the Callback interface for this window, used to intercept key
4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * events and other dynamic operations in the window.
4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param callback The desired Callback interface.
4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setCallback(Callback callback) {
4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mCallback = callback;
4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the current Callback interface for this window.
4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final Callback getCallback() {
4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mCallback;
4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
476dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn     * Take ownership of this window's surface.  The window's view hierarchy
477dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn     * will no longer draw into the surface, though it will otherwise continue
478dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn     * to operate (such as for receiving input events).  The given SurfaceHolder
479dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn     * callback will be used to tell you about state changes to the surface.
480dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn     */
481d76b67c340d1564abf8d14d976fdaf83bf2b3320Dianne Hackborn    public abstract void takeSurface(SurfaceHolder.Callback2 callback);
482dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn
483dc8a7f69d7df5f1ca29763995a0d55acf7936fc6Dianne Hackborn    /**
4841e4b9f3936d6f357e89360293e05a0e16d5fa440Dianne Hackborn     * Take ownership of this window's InputQueue.  The window will no
4851e4b9f3936d6f357e89360293e05a0e16d5fa440Dianne Hackborn     * longer read and dispatch input events from the queue; it is your
486a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn     * responsibility to do so.
487a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn     */
4881e4b9f3936d6f357e89360293e05a0e16d5fa440Dianne Hackborn    public abstract void takeInputQueue(InputQueue.Callback callback);
489a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn
490a95e4cb62f3642cb190d032dbf7dc40d9ecc6973Dianne Hackborn    /**
4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return whether this window is being displayed with a floating style
4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * (based on the {@link android.R.attr#windowIsFloating} attribute in
4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the style/theme).
4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Returns true if the window is configured to be displayed floating
4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * on top of whatever is behind it.
4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean isFloating();
4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the width and height layout parameters of the window.  The default
502980a938c1c9a6a5791a8240e5a1e6638ab28dc77Romain Guy     * for both of these is MATCH_PARENT; you can change them to WRAP_CONTENT to
5039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * make a window that is not full-screen.
5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param width The desired layout width of the window.
5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param height The desired layout height of the window.
5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setLayout(int width, int height)
5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    {
5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        attrs.width = width;
5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        attrs.height = height;
5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the gravity of the window, as per the Gravity constants.  This
5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * controls how the window manager is positioned in the overall window; it
5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * is only useful when using WRAP_CONTENT for the layout width or height.
5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param gravity The desired gravity constant.
5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see Gravity
5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setLayout
5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setGravity(int gravity)
5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    {
5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        attrs.gravity = gravity;
5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the type of the window, as per the WindowManager.LayoutParams
5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * types.
5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param type The new window type (see WindowManager.LayoutParams).
5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setType(int type) {
5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        attrs.type = type;
5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the format of window, as per the PixelFormat types.  This overrides
5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the default format that is selected by the Window based on its
5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * window decorations.
5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param format The new window format (see PixelFormat).  Use
5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *               PixelFormat.UNKNOWN to allow the Window to select
5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *               the format.
5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see PixelFormat
5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setFormat(int format) {
5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
5649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (format != PixelFormat.UNKNOWN) {
5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            attrs.format = format;
5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mHaveWindowFormat = true;
5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            attrs.format = mDefaultWindowFormat;
5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mHaveWindowFormat = false;
5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Specify custom animations to use for the window, as per
5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link WindowManager.LayoutParams#windowAnimations
5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * WindowManager.LayoutParams.windowAnimations}.  Providing anything besides
5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * 0 here will override the animations the window would
5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * normally retrieve from its theme.
5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setWindowAnimations(int resId) {
5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        attrs.windowAnimations = resId;
5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Specify an explicit soft input mode to use for the window, as per
5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link WindowManager.LayoutParams#softInputMode
5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * WindowManager.LayoutParams.softInputMode}.  Providing anything besides
5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * "unspecified" here will override the input mode the window would
5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * normally retrieve from its theme.
5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setSoftInputMode(int mode) {
5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mode != WindowManager.LayoutParams.SOFT_INPUT_STATE_UNSPECIFIED) {
6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            attrs.softInputMode = mode;
6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mHasSoftInputMode = true;
6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mHasSoftInputMode = false;
6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Convenience function to set the flag bits as specified in flags, as
6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * per {@link #setFlags}.
6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param flags The flag bits to be set.
6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setFlags
6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void addFlags(int flags) {
6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setFlags(flags, flags);
6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Convenience function to clear the flag bits as specified in flags, as
6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * per {@link #setFlags}.
6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param flags The flag bits to be cleared.
6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setFlags
6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void clearFlags(int flags) {
6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setFlags(0, flags);
6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the flags of the window, as per the
6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link WindowManager.LayoutParams WindowManager.LayoutParams}
6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * flags.
6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>Note that some flags must be set before the window decoration is
6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * created (by the first call to
6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)} or
6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #getDecorView()}:
6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link WindowManager.LayoutParams#FLAG_LAYOUT_IN_SCREEN} and
6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link WindowManager.LayoutParams#FLAG_LAYOUT_INSET_DECOR}.  These
6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * will be set for you based on the {@link android.R.attr#windowIsFloating}
6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * attribute.
6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param flags The new window flags (see WindowManager.LayoutParams).
6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param mask Which of the window flag bits to modify.
6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setFlags(int flags, int mask) {
6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final WindowManager.LayoutParams attrs = getAttributes();
6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        attrs.flags = (attrs.flags&~mask) | (flags&mask);
6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mForcedWindowFlags |= mask;
6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(attrs);
6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Specify custom window attributes.  <strong>PLEASE NOTE:</strong> the
6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * layout params you give here should generally be from values previously
6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * retrieved with {@link #getAttributes()}; you probably do not want to
6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * blindly create and apply your own, since this will blow away any values
6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * set by the framework that you are not interested in.
6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param a The new window attributes, which will completely override any
6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *          current values.
6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setAttributes(WindowManager.LayoutParams a) {
6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mWindowAttributes.copyFrom(a);
6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mCallback != null) {
6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mCallback.onWindowAttributesChanged(mWindowAttributes);
6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Retrieve the current window attributes associated with this panel.
6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return WindowManager.LayoutParams Either the existing window
6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         attributes object, or a freshly created one if there is none.
6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final WindowManager.LayoutParams getAttributes() {
6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mWindowAttributes;
6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the window flags that have been explicitly set by the client,
6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * so will not be modified by {@link #getDecorView}.
6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected final int getForcedWindowFlags() {
6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mForcedWindowFlags;
6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Has the app specified their own soft input mode?
6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected final boolean hasSoftInputMode() {
6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mHasSoftInputMode;
6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Enable extended screen features.  This must be called before
7019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * setContentView().  May be called as many times as desired as long as it
7029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * is before setContentView().  If not called, no extended features
7039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * will be available.  You can not turn off a feature once it is requested.
7049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * You canot use other title features with {@link #FEATURE_CUSTOM_TITLE}.
7059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param featureId The desired features, defined as constants by Window.
7079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return The features that are now set.
7089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean requestFeature(int featureId) {
7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final int flag = 1<<featureId;
7119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mFeatures |= flag;
7129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mLocalFeatures |= mContainer != null ? (flag&~mContainer.mFeatures) : flag;
7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mFeatures&flag) != 0;
7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final void makeActive() {
7179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mContainer != null) {
7189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (mContainer.mActiveChild != null) {
7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mContainer.mActiveChild.mIsActive = false;
7209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mContainer.mActiveChild = this;
7229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mIsActive = true;
7249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        onActive();
7259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final boolean isActive()
7289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    {
7299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mIsActive;
7309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Finds a view that was identified by the id attribute from the XML that
7349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * was processed in {@link android.app.Activity#onCreate}.  This will
7359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * implicitly call {@link #getDecorView} for you, with all of the
7369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * associated side-effects.
7379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return The view if found or null otherwise.
7399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public View findViewById(int id) {
7419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return getDecorView().findViewById(id);
7429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Convenience for
7469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)}
7479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to set the screen content from a layout resource.  The resource will be
7489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * inflated, adding all top-level views to the screen.
7499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param layoutResID Resource ID to be inflated.
7519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setContentView(View, android.view.ViewGroup.LayoutParams)
7529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setContentView(int layoutResID);
7549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Convenience for
7579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)}
7589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * set the screen content to an explicit view.  This view is placed
7599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * directly into the screen's view hierarchy.  It can itself be a complex
7609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * view hierarhcy.
7619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The desired content to display.
7639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setContentView(View, android.view.ViewGroup.LayoutParams)
7649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setContentView(View view);
7669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the screen content to an explicit view.  This view is placed
7699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * directly into the screen's view hierarchy.  It can itself be a complex
7709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * view hierarchy.
7719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>Note that calling this function "locks in" various characteristics
7739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * of the window that can not, from this point forward, be changed: the
7749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * features that have been requested with {@link #requestFeature(int)},
7759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and certain window flags as described in {@link #setFlags(int, int)}.
7769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The desired content to display.
7789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param params Layout parameters for the view.
7799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setContentView(View view, ViewGroup.LayoutParams params);
7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Variation on
7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)}
7859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to add an additional content view to the screen.  Added after any existing
7869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * ones in the screen -- existing views are NOT removed.
7879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The desired content to display.
7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param params Layout parameters for the view.
7909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void addContentView(View view, ViewGroup.LayoutParams params);
7929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the view in this Window that currently has focus, or null if
7959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * there are none.  Note that this does not look in any containing
7969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Window.
7979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return View The current View with focus or null.
7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract View getCurrentFocus();
8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Quick access to the {@link LayoutInflater} instance that this Window
8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * retrieved from its Context.
8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return LayoutInflater The shared LayoutInflater.
8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract LayoutInflater getLayoutInflater();
8099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setTitle(CharSequence title);
8119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setTitleColor(int textColor);
8139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void openPanel(int featureId, KeyEvent event);
8159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void closePanel(int featureId);
8179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void togglePanel(int featureId, KeyEvent event);
8199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean performPanelShortcut(int featureId,
8219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                                 int keyCode,
8229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                                 KeyEvent event,
8239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                                 int flags);
8249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean performPanelIdentifierAction(int featureId,
8259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                                 int id,
8269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                                 int flags);
8279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void closeAllPanels();
8299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean performContextMenuIdentifierAction(int id, int flags);
8319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Should be called when the configuration is changed.
8349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param newConfig The new configuration.
8369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void onConfigurationChanged(Configuration newConfig);
8389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Change the background of this window to a Drawable resource. Setting the
8419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * background to null will make the window be opaque. To make the window
8429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * transparent, you can use an empty drawable (for instance a ColorDrawable
8439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * with the color 0 or the system drawable android:drawable/empty.)
8449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param resid The resource identifier of a drawable resource which will be
8469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *              installed as the new background.
8479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setBackgroundDrawableResource(int resid)
8499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    {
8509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setBackgroundDrawable(mContext.getResources().getDrawable(resid));
8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Change the background of this window to a custom Drawable. Setting the
8559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * background to null will make the window be opaque. To make the window
8569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * transparent, you can use an empty drawable (for instance a ColorDrawable
8579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * with the color 0 or the system drawable android:drawable/empty.)
8589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param drawable The new Drawable to use for this window's background.
8609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setBackgroundDrawable(Drawable drawable);
8629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the value for a drawable feature of this window, from a resource
8659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * identifier.  You must have called requestFeauture(featureId) before
8669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * calling this function.
8679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see android.content.res.Resources#getDrawable(int)
8699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param featureId The desired drawable feature to change, defined as a
8719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * constant by Window.
8729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param resId Resource identifier of the desired image.
8739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setFeatureDrawableResource(int featureId, int resId);
8759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the value for a drawable feature of this window, from a URI. You
8789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * must have called requestFeature(featureId) before calling this
8799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * function.
8809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>The only URI currently supported is "content:", specifying an image
8829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * in a content provider.
8839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see android.widget.ImageView#setImageURI
8859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param featureId The desired drawable feature to change. Features are
8879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * constants defined by Window.
8889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param uri The desired URI.
8899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setFeatureDrawableUri(int featureId, Uri uri);
8919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set an explicit Drawable value for feature of this window. You must
8949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * have called requestFeature(featureId) before calling this function.
8959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param featureId The desired drawable feature to change.
8979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Features are constants defined by Window.
8989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param drawable A Drawable object to display.
8999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setFeatureDrawable(int featureId, Drawable drawable);
9019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set a custom alpha value for the given drawale feature, controlling how
9049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * much the background is visible through it.
9059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param featureId The desired drawable feature to change.
9079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Features are constants defined by Window.
9089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param alpha The alpha amount, 0 is completely transparent and 255 is
9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *              completely opaque.
9109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setFeatureDrawableAlpha(int featureId, int alpha);
9129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the integer value for a feature.  The range of the value depends on
9159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the feature being set.  For FEATURE_PROGRESSS, it should go from 0 to
9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * 10000. At 10000 the progress is complete and the indicator hidden.
9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param featureId The desired feature to change.
9199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Features are constants defined by Window.
9209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param value The value for the feature.  The interpretation of this
9219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *              value is feature-specific.
9229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setFeatureInt(int featureId, int value);
9249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Request that key events come to this activity. Use this if your
9279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * activity has no views with focus, but the activity still wants
9289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * a chance to process key events.
9299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void takeKeyEvents(boolean get);
9319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Used by custom windows, such as Dialog, to pass the key press event
9349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * further down the view hierarchy. Application developers should
9359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * not need to implement or call this.
9369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean superDispatchKeyEvent(KeyEvent event);
9399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Used by custom windows, such as Dialog, to pass the touch screen event
9429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * further down the view hierarchy. Application developers should
9439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * not need to implement or call this.
9449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean superDispatchTouchEvent(MotionEvent event);
9479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Used by custom windows, such as Dialog, to pass the trackball event
9509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * further down the view hierarchy. Application developers should
9519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * not need to implement or call this.
9529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean superDispatchTrackballEvent(MotionEvent event);
9559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Retrieve the top-level window decor view (containing the standard
9589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * window frame/decorations and the client's content inside of that), which
9599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * can be added as a window to the window manager.
9609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p><em>Note that calling this function for the first time "locks in"
9629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * various window characteristics as described in
9639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setContentView(View, android.view.ViewGroup.LayoutParams)}.</em></p>
9649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Returns the top-level window decor view.
9669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract View getDecorView();
9689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Retrieve the current decor view, but only if it has already been created;
9719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * otherwise returns null.
9729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Returns the top-level window decor or null.
9749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #getDecorView
9759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract View peekDecorView();
9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract Bundle saveHierarchyState();
9799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void restoreHierarchyState(Bundle savedInstanceState);
9819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected abstract void onActive();
9839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the feature bits that are enabled.  This is the set of features
9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * that were given to requestFeature(), and are being handled by this
9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Window itself or its container.  That is, it is the set of
9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * requested features that you can actually use.
9899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>To do: add a public version of this API that allows you to check for
9919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * features by their feature ID.
9929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return int The feature bits.
9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected final int getFeatures()
9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    {
9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mFeatures;
9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the feature bits that are being implemented by this Window.
10029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * This is the set of features that were given to requestFeature(), and are
10039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * being handled by only this Window itself, not by its containers.
10049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return int The feature bits.
10069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected final int getLocalFeatures()
10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    {
10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mLocalFeatures;
10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the default format of window, as per the PixelFormat types.  This
10149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * is the format that will be used unless the client specifies in explicit
10159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * format with setFormat();
10169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param format The new window format (see PixelFormat).
10189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setFormat
10209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see PixelFormat
10219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    protected void setDefaultWindowFormat(int format) {
10239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mDefaultWindowFormat = format;
10249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!mHaveWindowFormat) {
10259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            final WindowManager.LayoutParams attrs = getAttributes();
10269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            attrs.format = format;
10279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (mCallback != null) {
10289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                mCallback.onWindowAttributesChanged(attrs);
10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setChildDrawable(int featureId, Drawable drawable);
10349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setChildInt(int featureId, int value);
10369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Is a keypress one of the defined shortcut keys for this window.
10399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param keyCode the key code from {@link android.view.KeyEvent} to check.
10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param event the {@link android.view.KeyEvent} to use to help check.
10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract boolean isShortcutKey(int keyCode, KeyEvent event);
10439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see android.app.Activity#setVolumeControlStream(int)
10469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract void setVolumeControlStream(int streamType);
10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see android.app.Activity#getVolumeControlStream()
10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public abstract int getVolumeControlStream();
10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
1055