android -- ContextMenu 的使用 和 OptionsMenu 區別

菜單是用戶界面中最常見的元素之一,使用非常頻繁,在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"
    />

運行結果:

ContextMenu  menu


onCreateOptionsMenu --> 圖片文字

1 方法一,文字圖標在xml規劃好,文字定義在string.xml,圖片直接從工程文件中調用,至於所有的文字圖片排版,放在單獨的menu.xml文件中

  1. @Override  
  2.     public boolean onCreateOptionsMenu(Menu menu) {  
  3.         super.onCreateOptionsMenu(menu);  
  4.         MenuInflater menuInflater = getMenuInflater();  
  5.         menuInflater.inflate(R.menu.menu, menu);  
  6.         return true;  
  7.     }  
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <menu xmlns:android="http://schemas.android.com/apk/res/android">  
  3.     <item android:icon="@android:drawable/ic_menu_mylocation"  
  4.         android:id="@+id/centerOnLocationMenuItem" android:title="@string/myLocation" />  
  5.     <item android:icon="@android:drawable/ic_menu_more" android:id="@+id/chooseStop"  
  6.         android:title="@string/chooseStop" />  
  7.     <item android:icon="@android:drawable/ic_menu_mylocation"  
  8.         android:id="@+id/centerOnBostonMenuItem" android:title="@string/bostonsLocation" />  
  9.     <item android:icon="@android:drawable/ic_menu_preferences"  
  10.         android:id="@+id/settingsMenuItem" android:title="@string/settings" />  
  11.     <item android:icon="@android:drawable/ic_menu_more" android:id="@+id/chooseRoute"  
  12.         android:title="@string/chooseRoute" />  
  13.     <item android:icon="@android:drawable/ic_menu_rotate" android:id="@+id/refreshItem"  
  14.         android:title="@string/refresh" />  
  15. </menu>  


2,動態創建菜單

  1. @Override  
  2. public boolean onCreateOptionsMenu(Menu menu) {  
  3.     // TODO Auto-generated method stub  
  4.     menu.add(0, LOCATION, 1, R.string.location);  
  5.     menu.add(0,SEARCH,2,R.string.search);  
  6.     menu.add(0, SHOWROUTE, 3, R.string.vechicleLocation);  
  7.     menu.add(0, ALLROUTE, 4, R.string.allRoute);  
  8.     return super.onCreateOptionsMenu(menu);  
  9. }  
  1. public boolean onCreateOptionsMenu(Menu menu)  
  2. {  
  3.     menu.add(0, CLASSIC_MENU_REFRESH, 0, R.string.menu_refresh).setIcon(R.drawable.cmcc_toolbar_refresh);  
  4.     return super.onCreateOptionsMenu(menu);  


發佈了54 篇原創文章 · 獲贊 3 · 訪問量 44萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章