Android Menu 之 optionsMenu 詳解

optionsMenu就是用戶在按下手機鍵盤上的Menu鍵時,Activity下方彈出的菜單。借個圖展示一下:

接下來,本文的主要內容有:

1、 如何建立菜單

2、 如何響應菜單上的點擊動作

3、 講解Menu的各種屬性及Group分組

首先,如何建立菜單。

其實每個Activity都有處理菜單的能力,我們只需要重寫onCreateOptionsMenu(Menu menu)這個方法就可以建立菜單了。具體操作起來有兩種方法。

方法一,直接用代碼構建Menu

@Override public boolean onCreateOptionsMenu(Menu menu){ // 方法一,用代碼構建 menu.add(Menu.NONE, Menu.NONE, 1, "菜單1"); menu.add(Menu.NONE, Menu.NONE, 2, "菜單2"); menu.add(Menu.NONE, Menu.NONE, 3, "菜單3"); menu.add(Menu.NONE, Menu.NONE, 4, "菜單4"); menu.add(Menu.NONE, Menu.NONE, 5, "菜單5"); menu.add(Menu.NONE, Menu.NONE, 6, "菜單6"); return true; }

方法二,先用xml文件構建好Menu,再到代碼里加載。

例如,res/menu/option_menu_1.xml內容如下:

<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android"> <group android:id="@+id/logined" android:menuCategory="alternative"> <item android:id="@+id/item1" android:title="菜單1" android:orderInCategory="2" android:icon="@drawable/menu_serach_user"></item> <item android:id="@+id/item2" android:title="菜單2" android:orderInCategory="6" android:icon="@drawable/menu_backhome"></item></group> <group android:id="@+id/unlogin" android:menuCategory="container"> <item android:id="@+id/item3" android:title="菜單3" android:orderInCategory="5" android:icon="@drawable/menu_quit"></item> <item android:id="@+id/item4" android:orderInCategory="4" android:title="菜單4" android:icon="@drawable/menu_setting_center"></item> </group> </menu>

則在Activity裏這樣寫:

@Override public boolean onCreateOptionsMenu(Menu menu){ MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.option_menu_1, menu); return true; }

其次,如何響應菜單上的點擊動作

我們只需要重寫onOptionsItemSelected(MenuItem item)這個方法就可以做響應的操作了。代碼如下:

@Override public boolean onOptionsItemSelected(MenuItem item){ Toast.makeText(this, item.getOrder()+","+item.getTitle(), Toast.LENGTH_LONG).show(); return true; }

最後,在設置Menu的時候,有些屬性值得一說。

第一個,Item的屬性:menuCategory,它的取值一共有四個。我們可以在xml文件中寫上android:menuCategory="container",也可以在用代碼構建Menu時這樣寫:menu.add(groupid,itemid,Menu.CATEGORY_CONTAINER,title);四個取值的具體內容可以參見API中Menu的靜態屬性部分。那這四個分類是有什麼用的呢?根據API資料,這個分類應該是跟菜單展示時各項的排序有關係的。但是我試過不同的菜單項設不同的MenuCategory值,但結果並不是預期的那樣,預期是:數值越小的越靠上,靠左。但有一點可以確認,MenuCategory不設值(默認爲0)時,菜單項是排在最左上角的。

第二個,Item的屬性:orderInCategory,它的取值是0-0xffff之間的整數。也是設置排序順序的。它跟第一個屬性有啥關係呢?就是一個菜單項最終的Order值是MenuCategory值與orderInCategory值相加的結果。

還有Group分組,在xml創建Menu時,已經演示了Group的使用。我們使用Group是爲了方便處理那些擁有相同特徵的菜單項。比如有幾個菜單是要登錄了纔可以使用,或者部分菜單項前面要加選擇框,那我們就可以將它們放到一組,後面對這一個組進行操作就行了。

最後再補充一個對Menu進行樣式設置的問題。API中沒有提供設置背景等的方法。有朋友已經解決了些問題。在此貼上鍊接。

http://blog.csdn.net/sodino/archive/2011/01/26/6165132.aspx