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
19696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powellimport com.android.internal.view.menu.MenuView.ItemView;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
216eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikovimport android.annotation.Nullable;
22151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powellimport android.content.ActivityNotFoundException;
2381cf3ecadefb8fd6c05771b0b9947babaa9c8eafAdam Powellimport android.content.Context;
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Intent;
256eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikovimport android.content.res.ColorStateList;
26d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheevimport android.content.res.Resources;
276eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikovimport android.graphics.PorterDuff;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.drawable.Drawable;
29151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powellimport android.util.Log;
3051ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganovimport android.view.ActionProvider;
31696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powellimport android.view.ContextMenu.ContextMenuInfo;
32e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwalimport android.view.KeyEvent;
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.LayoutInflater;
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.MenuItem;
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.SubMenu;
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.View;
37d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheevimport android.view.ViewConfiguration;
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.ViewDebug;
3981cf3ecadefb8fd6c05771b0b9947babaa9c8eafAdam Powellimport android.widget.LinearLayout;
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @hide
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic final class MenuItemImpl implements MenuItem {
45151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell    private static final String TAG = "MenuItemImpl";
466eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
47d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell    private static final int SHOW_AS_ACTION_MASK = SHOW_AS_ACTION_NEVER |
48d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell            SHOW_AS_ACTION_IF_ROOM |
49d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell            SHOW_AS_ACTION_ALWAYS;
50d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final int mId;
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final int mGroup;
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final int mCategoryOrder;
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final int mOrdering;
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private CharSequence mTitle;
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private CharSequence mTitleCondensed;
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Intent mIntent;
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private char mShortcutNumericChar;
59e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    private int mShortcutNumericModifiers = KeyEvent.META_CTRL_ON;
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private char mShortcutAlphabeticChar;
61e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    private int mShortcutAlphabeticModifiers = KeyEvent.META_CTRL_ON;
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** The icon's drawable which is only created as needed */
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Drawable mIconDrawable;
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The icon's resource ID which is used to get the Drawable when it is
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * needed (if the Drawable isn't already obtained--only one of the two is
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * needed).
696eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov     */
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private int mIconResId = NO_ICON;
716eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
726eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    private ColorStateList mIconTintList = null;
736eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    private PorterDuff.Mode mIconTintMode = null;
746eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    private boolean mHasIconTint = false;
756eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    private boolean mHasIconTintMode = false;
766eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    private boolean mNeedToApplyIconTint = false;
776eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** The menu to which this item belongs */
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private MenuBuilder mMenu;
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** If this item should launch a sub menu, this is the sub menu to launch */
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private SubMenuBuilder mSubMenu;
826eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Runnable mItemCallback;
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private MenuItem.OnMenuItemClickListener mClickListener;
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private int mFlags = ENABLED;
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final int CHECKABLE      = 0x00000001;
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final int CHECKED        = 0x00000002;
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final int EXCLUSIVE      = 0x00000004;
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final int HIDDEN         = 0x00000008;
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final int ENABLED        = 0x00000010;
9296675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    private static final int IS_ACTION      = 0x00000020;
9389e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell
9496675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    private int mShowAsAction = SHOW_AS_ACTION_NEVER;
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
96cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell    private View mActionView;
9751ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov    private ActionProvider mActionProvider;
988d02deabac62c4a68a335a7b3141795466362b89Adam Powell    private OnActionExpandListener mOnActionExpandListener;
998d02deabac62c4a68a335a7b3141795466362b89Adam Powell    private boolean mIsActionViewExpanded = false;
100cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** Used for the icon resource ID if this item does not have an icon */
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    static final int NO_ICON = 0;
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Current use case is for context menu: Extra information linked to the
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * View that added this item to the context menu.
1077039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev     */
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private ContextMenuInfo mMenuInfo;
1097039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
1107039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    private CharSequence mContentDescription;
1116a944ca17547e520ed4988125ee4c1f172c87946Vladislav Kaznacheev    private CharSequence mTooltipText;
1127039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
11451ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov     * Instantiates this menu item.
11551ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov     *
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param menu
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param group Item ordering grouping control. The item will be added after
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            all other items whose order is <= this number, and before any
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            that are larger than it. This can also be used to define
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            groups of items for batch state changes. Normally use 0.
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param id Unique item ID. Use 0 if you do not need a unique ID.
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param categoryOrder The ordering for this item.
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param title The text to display for the item.
1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    MenuItemImpl(MenuBuilder menu, int group, int id, int categoryOrder, int ordering,
1264d9861e7ec8488634d316b20981464de2ab7b6feAdam Powell            CharSequence title, int showAsAction) {
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mMenu = menu;
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mId = id;
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mGroup = group;
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mCategoryOrder = categoryOrder;
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mOrdering = ordering;
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTitle = title;
1344d9861e7ec8488634d316b20981464de2ab7b6feAdam Powell        mShowAsAction = showAsAction;
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1366eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Invokes the item by calling various listeners or callbacks.
1396eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov     *
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return true if the invocation was handled, false otherwise
1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean invoke() {
1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mClickListener != null &&
1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mClickListener.onMenuItemClick(this)) {
1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return true;
1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
14853023ffdeae781e9750a5ef90a31ee3f5e0c2b4cAlan Viverette        if (mMenu.dispatchMenuItemSelected(mMenu, this)) {
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return true;
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mItemCallback != null) {
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mItemCallback.run();
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return true;
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
15651ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov
1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mIntent != null) {
158151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell            try {
159151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell                mMenu.getContext().startActivity(mIntent);
160151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell                return true;
161151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell            } catch (ActivityNotFoundException e) {
162151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell                Log.e(TAG, "Can't find activity to handle intent; ignoring", e);
163151af19bf409a47424ddaa51e1ac4a0c532c4eb6Adam Powell            }
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
16551ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov
166961dd11895ce72e59bca124ef5bea4e4c1183099Adam Powell        if (mActionProvider != null && mActionProvider.onPerformDefaultAction()) {
16751ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov            return true;
16851ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        }
16951ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return false;
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1726eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isEnabled() {
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mFlags & ENABLED) != 0;
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setEnabled(boolean enabled) {
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (enabled) {
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mFlags |= ENABLED;
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mFlags &= ~ENABLED;
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
184696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
1856eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1886eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int getGroupId() {
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mGroup;
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @ViewDebug.CapturedViewProperty
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int getItemId() {
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mId;
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int getOrder() {
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mCategoryOrder;
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2016eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int getOrdering() {
2036eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        return mOrdering;
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2056eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public Intent getIntent() {
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mIntent;
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setIntent(Intent intent) {
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mIntent = intent;
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    Runnable getCallback() {
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mItemCallback;
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2186eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setCallback(Runnable callback) {
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mItemCallback = callback;
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
223e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
224101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public char getAlphabeticShortcut() {
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mShortcutAlphabeticChar;
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
229101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
230e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    public int getAlphabeticModifiers() {
231e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        return mShortcutAlphabeticModifiers;
232e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    }
233e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
234101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setAlphabeticShortcut(char alphaChar) {
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mShortcutAlphabeticChar == alphaChar) return this;
237e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mShortcutAlphabeticChar = Character.toLowerCase(alphaChar);
239e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
240696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
241e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
242e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        return this;
243e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    }
244e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
245101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
246e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    public MenuItem setAlphabeticShortcut(char alphaChar, int alphaModifiers){
247e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        if (mShortcutAlphabeticChar == alphaChar &&
248e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal                mShortcutAlphabeticModifiers == alphaModifiers) {
249e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal            return this;
250e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        }
251e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
2522ef1d0cfca010b398fef5b6ee242c110a823bb95Peeyush Agarwal        mShortcutAlphabeticChar = Character.toLowerCase(alphaChar);
253e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mShortcutAlphabeticModifiers = KeyEvent.normalizeMetaState(alphaModifiers);
254e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
255e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mMenu.onItemsChanged(false);
256e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
260101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public char getNumericShortcut() {
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mShortcutNumericChar;
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
265101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
266e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    public int getNumericModifiers() {
267e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        return mShortcutNumericModifiers;
268e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    }
269e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
270101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setNumericShortcut(char numericChar) {
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mShortcutNumericChar == numericChar) return this;
2736eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mShortcutNumericChar = numericChar;
2756eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
276696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
2776eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
281101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
282e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    public MenuItem setNumericShortcut(char numericChar, int numericModifiers){
283e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        if (mShortcutNumericChar == numericChar && mShortcutNumericModifiers == numericModifiers) {
284e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal            return this;
285e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        }
286e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
287e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mShortcutNumericChar = numericChar;
288e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mShortcutNumericModifiers = KeyEvent.normalizeMetaState(numericModifiers);
289e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
290e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mMenu.onItemsChanged(false);
291e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
292e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        return this;
293e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    }
294e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
295101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setShortcut(char numericChar, char alphaChar) {
2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mShortcutNumericChar = numericChar;
2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mShortcutAlphabeticChar = Character.toLowerCase(alphaChar);
2996eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
300696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
3016eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
305101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    @Override
306101ab58e260e11bf165e1eb00f58761c8657abcePeeyush Agarwal    public MenuItem setShortcut(char numericChar, char alphaChar, int numericModifiers,
307e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal            int alphaModifiers) {
308e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mShortcutNumericChar = numericChar;
309e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mShortcutNumericModifiers = KeyEvent.normalizeMetaState(numericModifiers);
3102ef1d0cfca010b398fef5b6ee242c110a823bb95Peeyush Agarwal        mShortcutAlphabeticChar = Character.toLowerCase(alphaChar);
311e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mShortcutAlphabeticModifiers = KeyEvent.normalizeMetaState(alphaModifiers);
312e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
313e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        mMenu.onItemsChanged(false);
314e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
315e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal        return this;
316e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal    }
317e631e32a1a771a36267af3f8af8b64e9365bc19ePeeyush Agarwal
3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return The active shortcut (based on QWERTY-mode of the menu).
3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    char getShortcut() {
3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mMenu.isQwertyMode() ? mShortcutAlphabeticChar : mShortcutNumericChar);
3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3246eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return The label to show for the shortcut. This includes the chording
3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         key (for example 'Menu+a'). Also, any non-human readable
3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         characters should be human readable (for example 'Menu+enter').
3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    String getShortcutLabel() {
3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        char shortcut = getShortcut();
3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (shortcut == 0) {
3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return "";
3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3366eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
337d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        final Resources res = mMenu.getContext().getResources();
338d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev
339d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        StringBuilder sb = new StringBuilder();
340d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        if (ViewConfiguration.get(mMenu.getContext()).hasPermanentMenuKey()) {
341d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            // Only prepend "Menu+" if there is a hardware menu key.
342d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            sb.append(res.getString(
343d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                com.android.internal.R.string.prepend_shortcut_label));
344d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        }
345d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev
346d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        final int modifiers =
347d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            mMenu.isQwertyMode() ? mShortcutAlphabeticModifiers : mShortcutNumericModifiers;
348d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        appendModifier(sb, modifiers, KeyEvent.META_META_ON, res.getString(
349d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            com.android.internal.R.string.menu_meta_shortcut_label));
350d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        appendModifier(sb, modifiers, KeyEvent.META_CTRL_ON, res.getString(
351d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            com.android.internal.R.string.menu_ctrl_shortcut_label));
352d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        appendModifier(sb, modifiers, KeyEvent.META_ALT_ON, res.getString(
353d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            com.android.internal.R.string.menu_alt_shortcut_label));
354d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        appendModifier(sb, modifiers, KeyEvent.META_SHIFT_ON, res.getString(
355d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            com.android.internal.R.string.menu_shift_shortcut_label));
356d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        appendModifier(sb, modifiers, KeyEvent.META_SYM_ON, res.getString(
357d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            com.android.internal.R.string.menu_sym_shortcut_label));
358d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        appendModifier(sb, modifiers, KeyEvent.META_FUNCTION_ON, res.getString(
359d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            com.android.internal.R.string.menu_function_shortcut_label));
360d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev
3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        switch (shortcut) {
3626eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            case '\n':
364d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                sb.append(res.getString(
365d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                    com.android.internal.R.string.menu_enter_shortcut_label));
3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                break;
3676eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            case '\b':
369d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                sb.append(res.getString(
370d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                    com.android.internal.R.string.menu_delete_shortcut_label));
3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                break;
3726eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            case ' ':
374d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                sb.append(res.getString(
375d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev                    com.android.internal.R.string.menu_space_shortcut_label));
3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                break;
3776eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            default:
3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                sb.append(shortcut);
3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                break;
3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3826eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return sb.toString();
3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3856eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
386d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev    private static void appendModifier(StringBuilder sb, int mask, int modifier, String label) {
387d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        if ((mask & modifier) == modifier) {
388d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev            sb.append(label);
389d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev        }
390d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev    }
391d842533f224280484839b77d016c2e8da697a0edVladislav Kaznacheev
3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Whether this menu item should be showing shortcuts (depends on
3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         whether the menu should show shortcuts and whether this item has
3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         a shortcut defined)
3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean shouldShowShortcut() {
3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Show shortcuts if the menu is supposed to show shortcuts AND this item has a shortcut
3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mMenu.isShortcutsVisible() && (getShortcut() != 0);
4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4016eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public SubMenu getSubMenu() {
4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mSubMenu;
4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean hasSubMenu() {
4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mSubMenu != null;
4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setSubMenu(SubMenuBuilder subMenu) {
4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mSubMenu = subMenu;
4126eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        subMenu.setHeaderTitle(getTitle());
4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4156eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @ViewDebug.CapturedViewProperty
4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public CharSequence getTitle() {
4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mTitle;
4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Gets the title for a particular {@link ItemView}
4236eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov     *
4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param itemView The ItemView that is receiving the title
4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Either the title or condensed title based on what the ItemView
4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         prefers
4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    CharSequence getTitleForItemView(MenuView.ItemView itemView) {
4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return ((itemView != null) && itemView.prefersCondensedTitle())
4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ? getTitleCondensed()
4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                : getTitle();
4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setTitle(CharSequence title) {
4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTitle = title;
4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
437696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
4386eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mSubMenu != null) {
4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mSubMenu.setHeaderTitle(title);
4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4426eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4456eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setTitle(int title) {
4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return setTitle(mMenu.getContext().getString(title));
4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4496eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public CharSequence getTitleCondensed() {
4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mTitleCondensed != null ? mTitleCondensed : mTitle;
4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4536eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setTitleCondensed(CharSequence title) {
4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mTitleCondensed = title;
4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4576eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        // Could use getTitle() in the loop below, but just cache what it would do here
4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (title == null) {
4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            title = mTitle;
4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4616eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
462696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
4636eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public Drawable getIcon() {
4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mIconDrawable != null) {
4696eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            return applyIconTintIfNecessary(mIconDrawable);
4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mIconResId != NO_ICON) {
473a41b78973db3dfde159f7d641f794f462ad323d3Chris Banes            Drawable icon =  mMenu.getContext().getDrawable(mIconResId);
474c4852a37186260bf688dc94a77a4ebd2a8290a02Adam Powell            mIconResId = NO_ICON;
475a41b78973db3dfde159f7d641f794f462ad323d3Chris Banes            mIconDrawable = icon;
4766eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            return applyIconTintIfNecessary(icon);
4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4786eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return null;
4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4816eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setIcon(Drawable icon) {
4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mIconResId = NO_ICON;
4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mIconDrawable = icon;
4856eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mNeedToApplyIconTint = true;
486696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
4876eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4906eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setIcon(int iconResId) {
4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mIconDrawable = null;
4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mIconResId = iconResId;
4946eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mNeedToApplyIconTint = true;
4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // If we have a view, we need to push the Drawable to them
497696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mMenu.onItemsChanged(false);
4986eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5016eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5026eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    @Override
5036eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    public MenuItem setIconTintList(@Nullable ColorStateList iconTintList) {
5046eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mIconTintList = iconTintList;
5056eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mHasIconTint = true;
5066eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mNeedToApplyIconTint = true;
5076eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5086eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mMenu.onItemsChanged(false);
5096eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5106eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        return this;
5116eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    }
5126eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5136eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    @Nullable
5146eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    @Override
5156eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    public ColorStateList getIconTintList() {
5166eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        return mIconTintList;
5176eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    }
5186eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5196eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    @Override
5206eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    public MenuItem setIconTintMode(PorterDuff.Mode iconTintMode) {
5216eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mIconTintMode = iconTintMode;
5226eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mHasIconTintMode = true;
5236eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mNeedToApplyIconTint = true;
5246eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5256eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        mMenu.onItemsChanged(false);
5266eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5276eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        return this;
5286eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    }
5296eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5306eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    @Nullable
5316eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    @Override
5326eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    public PorterDuff.Mode getIconTintMode() {
5336eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        return mIconTintMode;
5346eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    }
5356eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5366eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    private Drawable applyIconTintIfNecessary(Drawable icon) {
5376eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        if (icon != null && mNeedToApplyIconTint && (mHasIconTint || mHasIconTintMode)) {
5386eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            icon = icon.mutate();
5396eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5406eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            if (mHasIconTint) {
5416eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov                icon.setTintList(mIconTintList);
5426eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            }
5436eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5446eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            if (mHasIconTintMode) {
5456eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov                icon.setTintMode(mIconTintMode);
5466eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            }
5476eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5486eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov            mNeedToApplyIconTint = false;
5496eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        }
5506eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5516eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov        return icon;
5526eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov    }
5536eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isCheckable() {
5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mFlags & CHECKABLE) == CHECKABLE;
5569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setCheckable(boolean checkable) {
5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final int oldFlags = mFlags;
5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mFlags = (mFlags & ~CHECKABLE) | (checkable ? CHECKABLE : 0);
5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (oldFlags != mFlags) {
562696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell            mMenu.onItemsChanged(false);
5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5646eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
568696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell    public void setExclusiveCheckable(boolean exclusive) {
569696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        mFlags = (mFlags & ~EXCLUSIVE) | (exclusive ? EXCLUSIVE : 0);
5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isExclusiveCheckable() {
5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mFlags & EXCLUSIVE) != 0;
5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5756eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isChecked() {
5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mFlags & CHECKED) == CHECKED;
5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setChecked(boolean checked) {
5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if ((mFlags & EXCLUSIVE) != 0) {
5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Call the method on the Menu since it knows about the others in this
5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // exclusive checkable group
5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mMenu.setExclusiveItemChecked(this);
5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            setCheckedInt(checked);
5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5886eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setCheckedInt(boolean checked) {
5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final int oldFlags = mFlags;
5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mFlags = (mFlags & ~CHECKED) | (checked ? CHECKED : 0);
5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (oldFlags != mFlags) {
596696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell            mMenu.onItemsChanged(false);
5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5996eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isVisible() {
601130b4572d1f3df702e5b296a655d15a41f6d4c66Adam Powell        if (mActionProvider != null && mActionProvider.overridesItemVisibility()) {
602130b4572d1f3df702e5b296a655d15a41f6d4c66Adam Powell            return (mFlags & HIDDEN) == 0 && mActionProvider.isVisible();
603130b4572d1f3df702e5b296a655d15a41f6d4c66Adam Powell        }
6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return (mFlags & HIDDEN) == 0;
6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Changes the visibility of the item. This method DOES NOT notify the
6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * parent menu of a change in this item, so this should only be called from
6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * methods that will eventually trigger this change.  If unsure, use {@link #setVisible(boolean)}
6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * instead.
6126eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov     *
6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param shown Whether to show (true) or hide (false).
6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Whether the item's shown state was changed
6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean setVisibleInt(boolean shown) {
6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        final int oldFlags = mFlags;
6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mFlags = (mFlags & ~HIDDEN) | (shown ? 0 : HIDDEN);
6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return oldFlags != mFlags;
6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6216eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public MenuItem setVisible(boolean shown) {
6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // Try to set the shown state to the given state. If the shown state was changed
6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // (i.e. the previous state isn't the same as given state), notify the parent menu that
6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        // the shown state has changed for this item
6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (setVisibleInt(shown)) mMenu.onItemVisibleChanged(this);
6276eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project   public MenuItem setOnMenuItemClickListener(MenuItem.OnMenuItemClickListener clickListener) {
6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mClickListener = clickListener;
6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return this;
6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6356eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @Override
6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public String toString() {
638cb923d99e9ec2f7b6b40a7c89c83a6caaa03b016Chet Haase        return mTitle != null ? mTitle.toString() : null;
6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void setMenuInfo(ContextMenuInfo menuInfo) {
6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mMenuInfo = menuInfo;
6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6446eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public ContextMenuInfo getMenuInfo() {
6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mMenuInfo;
6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
64935aecd5884a5ccfe380903e39f30f468315e8f92Adam Powell    public void actionFormatChanged() {
65035aecd5884a5ccfe380903e39f30f468315e8f92Adam Powell        mMenu.onItemActionRequestChanged(this);
65135aecd5884a5ccfe380903e39f30f468315e8f92Adam Powell    }
65235aecd5884a5ccfe380903e39f30f468315e8f92Adam Powell
6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
654696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell     * @return Whether the menu should show icons for menu items.
6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
656696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell    public boolean shouldShowIcon() {
657696cba573e651b0e4f18a4718627c8ccecb3bda0Adam Powell        return mMenu.getOptionalIconsVisible();
6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6596eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
66096675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    public boolean isActionButton() {
661ea1ca952c625d51dc71e1cc3d955b239921888c7Adam Powell        return (mFlags & IS_ACTION) == IS_ACTION;
66296675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    }
6636eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
66496675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    public boolean requestsActionButton() {
665d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell        return (mShowAsAction & SHOW_AS_ACTION_IF_ROOM) == SHOW_AS_ACTION_IF_ROOM;
66696675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    }
6676eea0d2a4ce20c9709d2cc9c24c823f7ef795c0aKirill Grouchnikov
66896675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    public boolean requiresActionButton() {
669d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell        return (mShowAsAction & SHOW_AS_ACTION_ALWAYS) == SHOW_AS_ACTION_ALWAYS;
67096675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    }
67196675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell
672484c2e2fbec02209337bb86fc99b8b253bc06f99Siyamed Sinir    @Override
673484c2e2fbec02209337bb86fc99b8b253bc06f99Siyamed Sinir    public boolean requiresOverflow() {
6749c881f227b2a136193a0a9236100075363a76f68Abodunrinwa Toki        return !requiresActionButton() && !requestsActionButton();
675484c2e2fbec02209337bb86fc99b8b253bc06f99Siyamed Sinir    }
676484c2e2fbec02209337bb86fc99b8b253bc06f99Siyamed Sinir
67796675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    public void setIsActionButton(boolean isActionButton) {
67896675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell        if (isActionButton) {
67996675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell            mFlags |= IS_ACTION;
68096675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell        } else {
68196675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell            mFlags &= ~IS_ACTION;
68296675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell        }
68396675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    }
68489e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell
685d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell    public boolean showsTextAsAction() {
68635aecd5884a5ccfe380903e39f30f468315e8f92Adam Powell        return (mShowAsAction & SHOW_AS_ACTION_WITH_TEXT) == SHOW_AS_ACTION_WITH_TEXT;
687d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell    }
688d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell
68996675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    public void setShowAsAction(int actionEnum) {
690d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell        switch (actionEnum & SHOW_AS_ACTION_MASK) {
691d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell            case SHOW_AS_ACTION_ALWAYS:
692d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell            case SHOW_AS_ACTION_IF_ROOM:
693d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell            case SHOW_AS_ACTION_NEVER:
694d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell                // Looks good!
695d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell                break;
696d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell
697d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell            default:
698d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell                // Mutually exclusive options selected!
699d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell                throw new IllegalArgumentException("SHOW_AS_ACTION_ALWAYS, SHOW_AS_ACTION_IF_ROOM,"
700d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell                        + " and SHOW_AS_ACTION_NEVER are mutually exclusive.");
701d8404b23739b135060ab9a04317a9f8b990cf8caAdam Powell        }
70296675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell        mShowAsAction = actionEnum;
70396675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell        mMenu.onItemActionRequestChanged(this);
70496675b1df3969f2d313b68f60ed9fa36805db8ceAdam Powell    }
705cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell
706cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell    public MenuItem setActionView(View view) {
707cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell        mActionView = view;
70851ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        mActionProvider = null;
709038f1c80af06da55056120e121d43e3ee89ec726Adam Powell        if (view != null && view.getId() == View.NO_ID && mId > 0) {
710038f1c80af06da55056120e121d43e3ee89ec726Adam Powell            view.setId(mId);
711038f1c80af06da55056120e121d43e3ee89ec726Adam Powell        }
712abbcc241c0db3d9167b5e6baeac1a07f009a05a5Adam Powell        mMenu.onItemActionRequestChanged(this);
713cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell        return this;
714cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell    }
715cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell
7163f476b34049d062942eafcf48396f593e00bd324Adam Powell    public MenuItem setActionView(int resId) {
71781cf3ecadefb8fd6c05771b0b9947babaa9c8eafAdam Powell        final Context context = mMenu.getContext();
71881cf3ecadefb8fd6c05771b0b9947babaa9c8eafAdam Powell        final LayoutInflater inflater = LayoutInflater.from(context);
71910da590839e264735de8a4582021aca0dab81037Amith Yamasani        setActionView(inflater.inflate(resId, new LinearLayout(context), false));
7203f476b34049d062942eafcf48396f593e00bd324Adam Powell        return this;
7213f476b34049d062942eafcf48396f593e00bd324Adam Powell    }
7223f476b34049d062942eafcf48396f593e00bd324Adam Powell
723cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell    public View getActionView() {
72451ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        if (mActionView != null) {
72551ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov            return mActionView;
72651ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        } else if (mActionProvider != null) {
727690ffb4e1f735148a15f2036d9a3c1962fba188cAdam Powell            mActionView = mActionProvider.onCreateActionView(this);
72851ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov            return mActionView;
72951ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        } else {
73051ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov            return null;
73151ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        }
73251ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov    }
73351ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov
73451ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov    public ActionProvider getActionProvider() {
73551ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        return mActionProvider;
73651ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov    }
73751ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov
73851ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov    public MenuItem setActionProvider(ActionProvider actionProvider) {
73939d5c6172503620ac3761148adac5fd7fa20d02dAdam Powell        if (mActionProvider != null) {
740c8f6ecc265656cdf68d2010a4e04666017c3b907Chris Banes            mActionProvider.reset();
74139d5c6172503620ac3761148adac5fd7fa20d02dAdam Powell        }
74251ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        mActionView = null;
74351ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        mActionProvider = actionProvider;
74423f4cc0353615107cc9c19fda9cf96ddd43266e2Adam Powell        mMenu.onItemsChanged(true); // Measurement can be changed
745dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell        if (mActionProvider != null) {
746dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell            mActionProvider.setVisibilityListener(new ActionProvider.VisibilityListener() {
747dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell                @Override public void onActionProviderVisibilityChanged(boolean isVisible) {
748dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell                    mMenu.onItemVisibleChanged(MenuItemImpl.this);
749dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell                }
750dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell            });
751dcc55855bc660fc2f45d02a1398be2e4fcf5fcb5Adam Powell        }
75251ac0e94a83cfccb5105aa14df1077729a5b4cccSvetoslav Ganov        return this;
753cf78b3e5101349fdddbde14b3a55140f9562ae66Adam Powell    }
7548d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7558d02deabac62c4a68a335a7b3141795466362b89Adam Powell    @Override
7568d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public MenuItem setShowAsActionFlags(int actionEnum) {
7578d02deabac62c4a68a335a7b3141795466362b89Adam Powell        setShowAsAction(actionEnum);
7588d02deabac62c4a68a335a7b3141795466362b89Adam Powell        return this;
7598d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
7608d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7618d02deabac62c4a68a335a7b3141795466362b89Adam Powell    @Override
7628d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public boolean expandActionView() {
7632dc27f22c9f2ff5de9f9e7d578391ba2abb9815cAdam Powell        if (!hasCollapsibleActionView()) {
7648d02deabac62c4a68a335a7b3141795466362b89Adam Powell            return false;
7658d02deabac62c4a68a335a7b3141795466362b89Adam Powell        }
7668d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7678d02deabac62c4a68a335a7b3141795466362b89Adam Powell        if (mOnActionExpandListener == null ||
7688d02deabac62c4a68a335a7b3141795466362b89Adam Powell                mOnActionExpandListener.onMenuItemActionExpand(this)) {
7698d02deabac62c4a68a335a7b3141795466362b89Adam Powell            return mMenu.expandItemActionView(this);
7708d02deabac62c4a68a335a7b3141795466362b89Adam Powell        }
7718d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7728d02deabac62c4a68a335a7b3141795466362b89Adam Powell        return false;
7738d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
7748d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7758d02deabac62c4a68a335a7b3141795466362b89Adam Powell    @Override
7768d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public boolean collapseActionView() {
7778d02deabac62c4a68a335a7b3141795466362b89Adam Powell        if ((mShowAsAction & SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW) == 0) {
7788d02deabac62c4a68a335a7b3141795466362b89Adam Powell            return false;
7798d02deabac62c4a68a335a7b3141795466362b89Adam Powell        }
7808d02deabac62c4a68a335a7b3141795466362b89Adam Powell        if (mActionView == null) {
7818d02deabac62c4a68a335a7b3141795466362b89Adam Powell            // We're already collapsed if we have no action view.
7828d02deabac62c4a68a335a7b3141795466362b89Adam Powell            return true;
7838d02deabac62c4a68a335a7b3141795466362b89Adam Powell        }
7848d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7858d02deabac62c4a68a335a7b3141795466362b89Adam Powell        if (mOnActionExpandListener == null ||
7868d02deabac62c4a68a335a7b3141795466362b89Adam Powell                mOnActionExpandListener.onMenuItemActionCollapse(this)) {
7878d02deabac62c4a68a335a7b3141795466362b89Adam Powell            return mMenu.collapseItemActionView(this);
7888d02deabac62c4a68a335a7b3141795466362b89Adam Powell        }
7898d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7908d02deabac62c4a68a335a7b3141795466362b89Adam Powell        return false;
7918d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
7928d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7938d02deabac62c4a68a335a7b3141795466362b89Adam Powell    @Override
7948d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public MenuItem setOnActionExpandListener(OnActionExpandListener listener) {
7958d02deabac62c4a68a335a7b3141795466362b89Adam Powell        mOnActionExpandListener = listener;
7968d02deabac62c4a68a335a7b3141795466362b89Adam Powell        return this;
7978d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
7988d02deabac62c4a68a335a7b3141795466362b89Adam Powell
7998d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public boolean hasCollapsibleActionView() {
800b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell        if ((mShowAsAction & SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW) != 0) {
801b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell            if (mActionView == null && mActionProvider != null) {
802b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell                mActionView = mActionProvider.onCreateActionView(this);
803b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell            }
804b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell            return mActionView != null;
805b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell        }
806b4c8ba49ac6ccce8e5c7904741f4adff05e37640Adam Powell        return false;
8078d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
8088d02deabac62c4a68a335a7b3141795466362b89Adam Powell
8098d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public void setActionViewExpanded(boolean isExpanded) {
8108d02deabac62c4a68a335a7b3141795466362b89Adam Powell        mIsActionViewExpanded = isExpanded;
8118d02deabac62c4a68a335a7b3141795466362b89Adam Powell        mMenu.onItemsChanged(false);
8128d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
8138d02deabac62c4a68a335a7b3141795466362b89Adam Powell
8148d02deabac62c4a68a335a7b3141795466362b89Adam Powell    public boolean isActionViewExpanded() {
8158d02deabac62c4a68a335a7b3141795466362b89Adam Powell        return mIsActionViewExpanded;
8168d02deabac62c4a68a335a7b3141795466362b89Adam Powell    }
8177039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8187039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    @Override
8197039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    public MenuItem setContentDescription(CharSequence contentDescription) {
8207039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev        mContentDescription = contentDescription;
8217039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8227039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev        mMenu.onItemsChanged(false);
8237039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8247039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev        return this;
8257039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    }
8267039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8277039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    @Override
8287039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    public CharSequence getContentDescription() {
8297039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev        return mContentDescription;
8307039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    }
8317039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8327039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    @Override
8336a944ca17547e520ed4988125ee4c1f172c87946Vladislav Kaznacheev    public MenuItem setTooltipText(CharSequence tooltipText) {
8346a944ca17547e520ed4988125ee4c1f172c87946Vladislav Kaznacheev        mTooltipText = tooltipText;
8357039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8367039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev        mMenu.onItemsChanged(false);
8377039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8387039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev        return this;
8397039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    }
8407039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev
8417039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    @Override
8426a944ca17547e520ed4988125ee4c1f172c87946Vladislav Kaznacheev    public CharSequence getTooltipText() {
8436a944ca17547e520ed4988125ee4c1f172c87946Vladislav Kaznacheev        return mTooltipText;
8447039cbc6f3a596aee6851014019849490f358f13Vladislav Kaznacheev    }
8459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
846