何為選項(xiàng)菜單?
選項(xiàng)菜單是某個(gè)Activity的主菜單項(xiàng)鹦倚,供您放置對(duì)應(yīng)用產(chǎn)生全局影響的操作涩赢,如“搜索”、“撰寫電子郵件”和設(shè)置耸彪。選項(xiàng)菜單中的項(xiàng)目在屏幕上的顯示位置取決于您開發(fā)應(yīng)用所使用的 Android 版本:
-
如果您開發(fā)的應(yīng)用適用于 Android 2.3.x (API 級(jí)別10)或更低版本,選項(xiàng)菜單的內(nèi)容會(huì)出現(xiàn)在屏幕底部如下圖所示忘苛,且當(dāng)菜單項(xiàng)超過6個(gè)時(shí)蝉娜,則會(huì)講第六項(xiàng)和其余項(xiàng)目放入溢出菜單(即圖中的 More 菜單項(xiàng))中唱较。
-
如果您開發(fā)的應(yīng)用適用于 Android 3.0 (API 級(jí)別 11)及更高版本,選項(xiàng)菜單的內(nèi)容將出現(xiàn)在應(yīng)用欄中如下圖所示召川。默認(rèn)情況下南缓,系統(tǒng)會(huì)將所有的菜單項(xiàng)放入操作溢出菜單(即圖中標(biāo)號(hào)為3的菜單項(xiàng))中。
創(chuàng)建menu資源文件
首先我在 app/src/mian/res/menu/ 目錄下創(chuàng)建一個(gè) my_menu.xml 文件
內(nèi)容如下:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/item1"
android:icon="@mipmap/ic_launcher"
android:title="item1"/>
<item
android:id="@+id/item2"
android:icon="@mipmap/ic_launcher"
android:title="item2"/>
<group
android:id="@+id/group"
android:checkableBehavior="single">
<item
android:id="@+id/group_item1"
android:icon="@mipmap/ic_launcher"
android:title="group_item1"/>
<item
android:id="@+id/group_item2"
android:icon="@mipmap/ic_launcher"
android:title="group_item2"/>
</group>
<item
android:id="@+id/submenu"
android:title="submenu_title">
<menu>
<item
android:id="@+id/submenu_item1"
android:title="submenu_item1"/>
</menu>
</item>
</menu>
從代碼中我們可以看出荧呐,菜單資源文件以<menu>
為根節(jié)點(diǎn)汉形,使用<item>
元素來定義菜單項(xiàng)。同時(shí)倍阐,我們也可以選擇使用<group>
元素來定義一個(gè)組概疆,來對(duì)組內(nèi)的菜單項(xiàng)的一些特性進(jìn)行統(tǒng)一的修改,比如是否可見峰搪。最后岔冀,可以看到我們以在<item>
元素中嵌套<menu>
元素的方式來創(chuàng)建子菜單。
<item>
元素的常用屬性:
- android:id 為菜單項(xiàng)指定一個(gè)唯一標(biāo)識(shí)
- android:title 指定菜單項(xiàng)的標(biāo)題
- android:icon 指定菜單項(xiàng)的圖標(biāo)
- android:showAsAction 指定菜單項(xiàng)作為操作項(xiàng)目顯示在應(yīng)用欄的時(shí)間和方式
<group>
元素的常用屬性
- android:id 為改組菜單指定一個(gè)唯一標(biāo)識(shí)
- android:checkableBehavior 指定改組菜單的選擇行為
- android:visible 指定改組菜單是否可見
- android:enable 指定改組菜單是否可用
更詳細(xì)的介紹請(qǐng)參考API文檔Menu部分概耻。
加載menu資源文件
通過重寫 onCreateOptionsMenu() 方法使套,來為 Activity 指定選項(xiàng)菜單。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.my_menu, menu);
return true;
}
}
運(yùn)行效果:
處理點(diǎn)擊事件
當(dāng)我們從選項(xiàng)菜單中選擇項(xiàng)目時(shí)鞠柄,系統(tǒng)將調(diào)用 Activity 的 onOptionsItemSelected() 方法侦高。 此方法將傳遞所選的 MenuItem,可以通過調(diào)用 getItemId() 方法來識(shí)別項(xiàng)目厌杜,該方法將返回菜單項(xiàng)的唯一 ID(由菜單資源中的 android:id 屬性定義)奉呛。 我們可以將此 ID 與已知的菜單項(xiàng)匹配,以執(zhí)行適當(dāng)?shù)牟僮髌诒肌@纾?/p>
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.my_menu, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.group_item1:
item.setChecked(true);
return true;
case R.id.group_item2:
item.setChecked(true);
return true;
default:
Toast.makeText(this, "selected " + item.getTitle(), Toast.LENGTH_SHORT).show();
return super.onOptionsItemSelected(item);
}
}
}
運(yùn)行效果:
總結(jié)
本文主要初步的介紹了如何使用 XML 定義選項(xiàng)菜單侧馅,定義其他類型菜單的方法類似危尿。更深入的了解和使用菜單請(qǐng)參考Android官方教程呐萌。關(guān)于即便設(shè)置showAsAction="always",items仍然在overflow中顯示的問題谊娇,請(qǐng)參考這篇文章肺孤。
ps:歡迎留言交流,共同進(jìn)步济欢。