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 com.android.internal.view.menu;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport com.android.internal.view.menu.MenuBuilder;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport com.android.internal.view.menu.MenuItemImpl;
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.drawable.Drawable;
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
25696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell * Minimal interface for a menu view.  {@link #initialize(MenuBuilder)} must be called for the
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * menu to be functional.
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @hide
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic interface MenuView {
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Initializes the menu to the given menu. This should be called after the
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * view is inflated.
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param menu The menu that this MenuView should display.
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
37696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell    public void initialize(MenuBuilder menu);
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns the default animations to be used for this menu when entering/exiting.
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return A resource ID for the default animations to be used for this menu.
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int getWindowAnimations();
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Minimal interface for a menu item view.  {@link #initialize(MenuItemImpl, int)} must be called
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * for the item to be functional.
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public interface ItemView {
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Initializes with the provided MenuItemData.  This should be called after the view is
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * inflated.
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param itemData The item that this ItemView should display.
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param menuType The type of this menu, one of
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *            {@link MenuBuilder#TYPE_ICON}, {@link MenuBuilder#TYPE_EXPANDED},
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *            {@link MenuBuilder#TYPE_DIALOG}).
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void initialize(MenuItemImpl itemData, int menuType);
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Gets the item data that this view is displaying.
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return the item data, or null if there is not one
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public MenuItemImpl getItemData();
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Sets the title of the item view.
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param title The title to set.
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setTitle(CharSequence title);
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Sets the enabled state of the item view.
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param enabled Whether the item view should be enabled.
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setEnabled(boolean enabled);
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Displays the checkbox for the item view.  This does not ensure the item view will be
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * checked, for that use {@link #setChecked}.
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param checkable Whether to display the checkbox or to hide it
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setCheckable(boolean checkable);
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Checks the checkbox for the item view.  If the checkbox is hidden, it will NOT be
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * made visible, call {@link #setCheckable(boolean)} for that.
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param checked Whether the checkbox should be checked
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setChecked(boolean checked);
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Sets the shortcut for the item.
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param showShortcut Whether a shortcut should be shown(if false, the value of
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * shortcutKey should be ignored).
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param shortcutKey The shortcut key that should be shown on the ItemView.
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setShortcut(boolean showShortcut, char shortcutKey);
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Set the icon of this item view.
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @param icon The icon of this item. null to hide the icon.
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void setIcon(Drawable icon);
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Whether this item view prefers displaying the condensed title rather
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * than the normal title. If a condensed title is not available, the
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * normal title will be used.
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return Whether this item view prefers displaying the condensed
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *         title.
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean prefersCondensedTitle();
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Whether this item view shows an icon.
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return Whether this item view shows an icon.
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public boolean showsIcon();
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
124