什麼是上下文菜單:
有時候我們也可以叫做快鍵菜單。例如我們在電腦桌面右鍵所看到的菜單就是快捷菜單,也叫上下文菜單,叫上下文菜單是因為Context翻譯成為上下文的意思
創建上下文ContextMenu菜單的步驟:
1、 覆蓋Activity的onCreateContextMenu()方法,調用Menu的add方法添加菜單項
2、 覆蓋onContexItemSelected()方法,響應菜單單擊事件
3、 調用registerForContexMenu()方法為視力註冊上下文菜單
public void onCreateContextMenu (ContextMenu menu,View v,ContextMenu.ContextMenuInfo menuInfo)
參數說明:
menu:需要顯示的快捷菜單
v:V是用戶選擇的界面元素
menuInfo:menuInfo是所選擇界面元素的額外信息
說明:這個onCreateContextMenu與onCreateOptionsMenu函數不一樣,onCreateOptionsMenu函數僅在選項菜單第一次啟動時被調用一次,而onCreateContextMenu函數在每次啟動都將會被調用一次。
public boolean onContextItemSelected (MenuItem item)
這個方法和前面的onMenuItemSelected大同小異,在此就不再多說明瞭
實例1:
package com.jiahui.activity;
import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.view.ContextMenu.ContextMenuInfo;
import android.widget.TextView;
public class ContextMenuDemoActivity extends Activity {
private static final int ITEM1 = Menu.FIRST;
private static final int ITEM2 = Menu.FIRST + 1;
private static final int ITEM3 = Menu.FIRST + 2;
private TextView myTxt;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
myTxt = (TextView) findViewById(R.id.mytxt);
// 向TextView控件註冊上下文菜單
registerForContextMenu(myTxt);
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
// 添加菜單項
menu.add(0, ITEM1, 0, "紅色背景");
menu.add(0, ITEM2, 0, "綠色背景");
menu.add(0, ITEM3, 0, "白色背景");
}
// 上下文菜單選中事項 通過選中不同的按鈕來改變TextView的背景顏色
@Override
public boolean onContextItemSelected(MenuItem item) {
switch (item.getItemId()) {
case ITEM1:
myTxt.setBackgroundColor(Color.RED);
break;
case ITEM2:
myTxt.setBackgroundColor(Color.GREEN);
break;
case ITEM3:
myTxt.setBackgroundColor(Color.WHITE);
break;
}
return true;
}
}
<?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:id="@+id/mytxt" android:layout_width="fill_parent"
android:layout_height="wrap_content" android:text="@string/hello" />
</LinearLayout>
效果:
實例2:用XML創建上下文菜單
需要通過Activity的getMenuInflater()返回一個MenuInflater對象,然後通過MenuInflater對象的inflater()方法指定XML文件的引用
public void inflate (int menuRes, Menu menu)
參數說明:
menuRes:XML文件的引用位置
menu:要顯示的菜單
package com.jiahui.activity;
import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.view.ContextMenu.ContextMenuInfo;
import android.widget.TextView;
public class ContextMenuDemoActivity extends Activity {
private static final int ITEM1 = Menu.FIRST;
private static final int ITEM2 = Menu.FIRST + 1;
private static final int ITEM3 = Menu.FIRST + 2;
private TextView myTxt;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
myTxt = (TextView) findViewById(R.id.mytxt);
// 向TextView控件註冊上下文菜單
registerForContextMenu(myTxt);
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
//XML方式創建的菜單項
MenuInflater inflater=getMenuInflater();
inflater.inflate(R.menu.context_menu, menu);
}
// 上下文菜單選中事項 通過選中不同的按鈕來改變TextView的背景顏色
@Override
public boolean onContextItemSelected(MenuItem item) {
switch (item.getItemId()) {
case ITEM1:
myTxt.setBackgroundColor(Color.RED);
break;
case ITEM2:
myTxt.setBackgroundColor(Color.GREEN);
break;
case ITEM3:
myTxt.setBackgroundColor(Color.WHITE);
break;
}
return true;
}
}
context_menu.xml:
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/contextMenu1" android:title="XML創建的菜單子項1"></item>
<item android:id="@+id/contextMenu2" android:title="XML創建的菜單子項2"></item>
<item android:id="@+id/contextMenu2" android:title="XML創建的菜單子項3"></item>
</menu>
效果:
摘自:jiahui524專欄