元素。
- :創(chuàng)建一個MenuItem,代表了菜單中一個選項。
:對菜單項進行分組,可以以組的形式操作菜單項。
- 元素除了常規(guī)的id、icon、title屬性的支持,還有一個重要的屬性:android:showAsAction,這個屬性是起兼容性的,描述了在Android的高版本中,菜單項何時以何種方式加入到ActionBar中。
是對菜單進行分組,分組后的菜單顯示效果并沒有區(qū)別,唯一的區(qū)別在于可以針對菜單組進行操作,這樣對于分類的菜單項,操作起來更方便,提供如下的操作:
Menu.setGroupCheckable():菜單組內(nèi)的菜單是否都可選。
Menu.setGroupVisible():是否隱藏菜單組的所有菜單。
Menu.setGroupEnabled():菜單組的菜單是否有用。
如果菜單項需要單選或者多選,可以使用android:checkableBehavior屬性設(shè)置,它可以對單個- 或者設(shè)置一個組,這個屬性接受三個參數(shù):single,單選;all,多選,none,沒有Checked的選項,默認。
當(dāng)創(chuàng)建好一個XML菜單資源文件之后,可以使用MenuInflater.inflate()方法填充菜單資源,使XML資源變成一個可編程的對象。
一、Options menu選項菜單:
OptionMenu,選項菜單,單擊手機上的菜單鍵(MENU)出現(xiàn),必須設(shè)備具有菜單按鈕才可以觸發(fā)。因為屏幕的限制,最多只能展示六個菜單項,如果定義的菜單項超出了六個,其他的菜單項將被隱藏,第六個菜單將會顯示“更多”,點擊展開更多的菜單。雖說在Android3.0之后不再推薦使用選項菜單,但是如果使用了,在Android3.0之后的設(shè)備上,選項菜單項將被默認轉(zhuǎn)移到ActionBar中,這個可以通過android:showAsAction屬性控制。
創(chuàng)建選項菜單的核心步驟:
(1)重寫Activity的onCreateOptionMenu(Menu menu)方法,當(dāng)菜單第一次被加載時調(diào)用
(2)調(diào)用Menu 的add( )方法添加菜單項(MenuItem),同時可以調(diào)用MenuItem的setIcon()方法為菜單項設(shè)置圖標(biāo)(注:Android 3.0之后,即使添加了圖標(biāo)也不會顯示)
(3)重寫Activity的OptionsItemSelected(MenuItem item)來響應(yīng)菜單項(MenuItem)的點擊事件
來看一下具體的代碼實現(xiàn):
新建Android工程MenuTest:
【方式一】通過配置文件添加Menu選項
(1)在res/menu/main.xml中定義菜單項。main.xml的代碼如下:
復(fù)制代碼
復(fù)制代碼
注:第9行和第15行的字符串引用,需要提前在strings.xml文件中設(shè)置好。
(2)MainActivity.java:
復(fù)制代碼
1 package com.example.menutest;
2
3 import android.app.Activity;
4 import android.os.Bundle;
5 import android.view.Menu;
6 import android.view.MenuItem;
7 import android.widget.Toast;
8
9
10 public class MainActivity extends Activity {
11
12 @Override
13 protected void onCreate(Bundle savedInstanceState) {
14 super.onCreate(savedInstanceState);
15 setContentView(R.layout.activity_main);
16 }
17
18
19 //重寫onCreateOptionMenu(Menu menu)方法,當(dāng)菜單第一次被加載時調(diào)用
20 @Override
21 public boolean onCreateOptionsMenu(Menu menu) {
22 // Inflate the menu; this adds items to the action bar if it is present.
23 //填充選項菜單(讀取XML文件、解析、加載到Menu組件上)
24 getMenuInflater().inflate(R.menu.main, menu);
25 return true;
26 }
27
28 //重寫OptionsItemSelected(MenuItem item)來響應(yīng)菜單項(MenuItem)的點擊事件(根據(jù)id來區(qū)分是哪個item)[!--empirenews.page--]
29 @Override
30 public boolean onOptionsItemSelected(MenuItem item) {
31 // Handle action bar item clicks here. The action bar will
32 // automatically handle clicks on the Home/Up button, so long
33 // as you specify a parent activity in AndroidManifest.xml.
34 switch (item.getItemId()) {
35 case R.id.start:
36 Toast.makeText(this, "開始游戲", Toast.LENGTH_SHORT).show();
37 break;
38 case R.id.over:
39 Toast.makeText(this, "結(jié)束游戲", Toast.LENGTH_SHORT).show();
40 break;
41
42 default:
43 break;
44 }
45 return super.onOptionsItemSelected(item);
46 }
47 }