菜單是用戶界面中最常見的元素之一,使用非常頻繁,在Android中,菜單被分爲如下三種,選項菜單(OptionsMenu)、上下文菜單(ContextMenu)和子菜單(SubMenu),今天這講是ContextMenu
1.選擇菜單OptionsMenu
點擊Menu key,顯示選擇菜單
實現方法.onCreateOptionsMenu()此方法只會調用一次,即第一次顯示的時候會調用.
如果需要更新菜單項.可以在onPrepareOptionsMenu()方法中操作.
當菜單被選擇的時候,在OnOptionsItemSelected()方法中實現.
2.上下文菜單ContextMenu
在view按2s,就會顯示上下文菜單.onCreateContextMenu每次都會調用.選中的時候,在onContextItemSelected()方法中實現.
概述:
Android 的上下文菜單類似於 PC 上的右鍵菜單。當爲一個視圖註冊了上下文菜單之後,長按(2 秒左右)這個視圖對象就會彈出一個浮動菜單,即上下文菜單。任何視圖都可以註冊上下文菜單,不過,最常見的是用於列表視圖ListView的item。
注意:Android 的上下文菜單不支持圖標或快捷鍵。
創建一個上下文菜單的步驟:
1. 覆蓋 Activity 的 onCreateContenxtMenu() 方法,調用 Menu 的 add 方法添加菜單項(MenuItem)。
2. 覆蓋 Activity 的 onContextItemSelected() 方法,響應上下文菜單菜單項的單擊事件。
3. 調用 registerForContextMenu() 方法,爲視圖註冊上下文菜單。
示例:
MainActivity.java 文件:
//file name: MainActivity.java
package hi.braincol.local.contextMenu;
import android.app.ListActivity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.Menu;
import android.view.MenuItem;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.View;
import android.widget.AdapterView.AdapterContextMenuInfo;
import android.widget.ArrayAdapter;
import android.util.Log;
public class MainActivity extends ListActivity {
private static final int ITEM1 = Menu.FIRST;
private static final int ITEM2 = Menu.FIRST+1;
private static final int ITEM3 = Menu.FIRST+2;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
showListView();
//爲 ListView 的所有 item 註冊 ContextMenu
registerForContextMenu(getListView());
//這裏的registerForContextMenu()也可以用下面的語句替代
//getListView().setOnCreateContextMenuListener(this);
}
private void showListView(){
String[] mString = new String[]{
"路飛-Monkey D Luffy",
"奈美-Nami",
"卓洛-Zoro",
"山治-Sanji",
"尼可·羅賓-Ms. All Sunday",
"烏索普-usoppu",
"託尼託尼·喬巴-Tony Tony Chopper",
};
ArrayAdapter<String> mla = new ArrayAdapter<String>(MainActivity.this,
R.layout.main, mString);
MainActivity.this.setListAdapter(mla);
}
//上下文菜單,本例會通過長按條目激活上下文菜單
@Override
public void onCreateContextMenu(ContextMenu menu, View view,
ContextMenuInfo menuInfo) {
menu.setHeaderTitle("人物簡介");
//添加菜單項
menu.add(0, ITEM1, 0, "特長");
menu.add(0, ITEM2, 0, "戰鬥力");
menu.add(0, ITEM3, 0, "經典語錄");
}
//菜單單擊響應
@Override
public boolean onContextItemSelected(MenuItem item){
//獲取當前被選擇的菜單項的信息
//AdapterContextMenuInfo info = (AdapterContextMenuInfo)item.getMenuInfo();
//Log.i("braincol",String.valueOf(info.id));
switch(item.getItemId()){
case ITEM1:
//在這裏添加處理代碼
break;
case ITEM2:
//在這裏添加處理代碼
break;
case ITEM3:
//在這裏添加處理代碼
break;
}
return true;
}
}
main.xml 佈局文件:
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/myTextView"
android:textSize="20sp"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:text="@string/hello"
/>
運行結果:
onCreateOptionsMenu --> 圖片文字
1 方法一,文字圖標在xml規劃好,文字定義在string.xml,圖片直接從工程文件中調用,至於所有的文字圖片排版,放在單獨的menu.xml文件中
- @Override
- public boolean onCreateOptionsMenu(Menu menu) {
- super.onCreateOptionsMenu(menu);
- MenuInflater menuInflater = getMenuInflater();
- menuInflater.inflate(R.menu.menu, menu);
- return true;
- }
- <?xml version="1.0" encoding="UTF-8" ?>
- <menu xmlns:android="http://schemas.android.com/apk/res/android">
- <item android:icon="@android:drawable/ic_menu_mylocation"
- android:id="@+id/centerOnLocationMenuItem" android:title="@string/myLocation" />
- <item android:icon="@android:drawable/ic_menu_more" android:id="@+id/chooseStop"
- android:title="@string/chooseStop" />
- <item android:icon="@android:drawable/ic_menu_mylocation"
- android:id="@+id/centerOnBostonMenuItem" android:title="@string/bostonsLocation" />
- <item android:icon="@android:drawable/ic_menu_preferences"
- android:id="@+id/settingsMenuItem" android:title="@string/settings" />
- <item android:icon="@android:drawable/ic_menu_more" android:id="@+id/chooseRoute"
- android:title="@string/chooseRoute" />
- <item android:icon="@android:drawable/ic_menu_rotate" android:id="@+id/refreshItem"
- android:title="@string/refresh" />
- </menu>
2,動態創建菜單
- @Override
- public boolean onCreateOptionsMenu(Menu menu) {
- // TODO Auto-generated method stub
- menu.add(0, LOCATION, 1, R.string.location);
- menu.add(0,SEARCH,2,R.string.search);
- menu.add(0, SHOWROUTE, 3, R.string.vechicleLocation);
- menu.add(0, ALLROUTE, 4, R.string.allRoute);
- return super.onCreateOptionsMenu(menu);
- }
- public boolean onCreateOptionsMenu(Menu menu)
- {
- menu.add(0, CLASSIC_MENU_REFRESH, 0, R.string.menu_refresh).setIcon(R.drawable.cmcc_toolbar_refresh);
- return super.onCreateOptionsMenu(menu);
- }