Android系統中的ContextMenu(操作功能表)類似於PC中的右鍵快顯功能表,當一個視圖註冊到一個操作功能表時,執行一個在該對象上的“長按”動作,將出現一個提供相關功能的浮動菜單。操作功能表可以被註冊到任何視圖對象中,不過,最常見的是用於列表視圖ListView的item,在按中清單項目時,會轉換其背景色而提示將呈現操作功能表。
注意:操作功能表不支援表徵圖和快速鍵。
為了建立一個操作功能表,你必須重寫這個活動的操作功能表回呼函數:onCreateContextMenu() 和 onContextItemSelected()。在回呼函數onCreateContextMenu()裡,你可以通過使用一個add()方法來添加功能表項目,或者通過擴充一個定義在XML中的菜單資源。然後,通過registerForContextMenu()為這個視圖註冊一個操作功能表ContextMenu.
下面我通過一個執行個體Demo來展示下ContextMenu的基本使用,通過手動添加Menu菜單和XML檔案兩種方式來配置Menu的選項。
[1] 該Demo的工程結構目錄圖如下:
[2] res/layout目錄下的main.xml布局檔案源碼如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Hello,This is Andy's Blog!"/>
<ListView
android:id="@+id/lv"
android:layout_width="fill_parent"
android:layout_height="wrap_content"/>
</LinearLayout>
[3] res/menu目錄下的 cmenu.xml 菜單選項檔案源碼如下:
<?xml version="1.0" encoding="utf-8"?>
<menu
xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/add" android:title="增加"/>
<item android:id="@+id/update" android:title="更新"/>
<item android:id="@+id/delete" android:title="刪除"/>
</menu>
[4] com.andyidea.menudemo包下的 MenuActivity.java 源碼如下:
package com.andyidea.menudemo;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.Toast;
public class MenuActivity extends Activity {
ListView lv;
private ArrayAdapter<String> adapter;
private List<String> alist = new ArrayList<String>();
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
lv = (ListView)findViewById(R.id.lv);
alist.add("第一");
alist.add("第二");
alist.add("第三");
adapter = new ArrayAdapter<String>(this,android.R.layout.simple_expandable_list_item_1,alist);
lv.setAdapter(adapter);
//註冊視圖對象,即為ListView控制項註冊操作功能表
registerForContextMenu(lv);
}
/**
* 建立操作功能表選項
*/
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
//1.通過手動添加來配置操作功能表選項
//menu.add(0, 1, 0, "修改");
//menu.add(0, 2, 0, "刪除");
//2.通過xml檔案來配置操作功能表選項
MenuInflater mInflater = getMenuInflater();
mInflater.inflate(R.menu.cmenu, menu);
super.onCreateContextMenu(menu, v, menuInfo);
}
/**
* 當菜單某個選項被點擊時調用該方法
*/
@Override
public boolean onContextItemSelected(MenuItem item) {
switch(item.getItemId()){
case 1:
Toast.makeText(this, "你選擇了手動修改", Toast.LENGTH_SHORT).show();
break;
case 2:
Toast.makeText(this, "你選擇了手動刪除", Toast.LENGTH_SHORT).show();
break;
case R.id.add:
Toast.makeText(this, "你選擇了XML增加", Toast.LENGTH_SHORT).show();
break;
case R.id.update:
Toast.makeText(this, "你選擇了XML更新", Toast.LENGTH_SHORT).show();
break;
case R.id.delete:
Toast.makeText(this, "你選擇了XML刪除", Toast.LENGTH_SHORT).show();
break;
}
return super.onContextItemSelected(item);
}
/**
* 當操作功能表關閉時調用的方法
*/
@Override
public void onContextMenuClosed(Menu menu) {
// TODO Auto-generated method stub
super.onContextMenuClosed(menu);
}
}
[5] Demo運行後的運行如下:
摘自:Android-Idea