Menu使用

一、 使用xml定义Menu

菜单资源文件必须放在res/menu目录中。菜单资源文件必须使用<menu>标签作为根节点。除了<menu>标签外,还有另外两个标签用于设置菜单项和分组,这两个标签是<item>和<group>。

<menu>标签没有任何属性,但可以嵌套在<item>标签中,表示子菜单的形式。不过<item>标签中不能再嵌入<item>标签。

1.<item>标签的属性含义如下:

Id:表示菜单项的资源ID

menuCategory:同种菜单项的种类。该属性可取4个值:Container、system、secondary和alternative。通过menuCategroy属性可以控制菜单项的位置。例如将属性设为system,表示该菜单项是系统菜单,应放在其他种类菜单项的后面。

orderInCategor:同种类菜单的排列顺序。该属性需要设置一个整数值。例如menuCategory属性值都为system的3个菜单项(item1、item2和item3)。将这3个菜单项的orderInCategory属性值设为3、2、1,那么item3会显示在最前面,而item1会显示在最后面。

title:菜单项标题(菜单项显示的文本)

titleCondensed:菜单项的短标题。当菜单项标题太长时会显示该属性值

icon:菜单项图标资源ID

alphabeticShortcut:菜单项的字母快捷键

numericShortcut:菜单项的数字快捷键

checkable:表示菜单项是否带复选框。该属性可设计为true或false

checked:如果菜单项带复选框(checkable属性为true),该属性表示复选框默认状态是否被选中。可设置的值为true或false

visible:菜单项默认状态是否可视

enable:菜单项默认状态是否被激活

2.<group>标签的属性含义如下:

id:表示菜单组的ID

menuCategory:与<item>标签的同名属性含义相同。只是作用域为菜单组

orderInCategory:与<item>标签的同名属性含义相同。只是作用域为菜单组

checkableBehavior:设置该组所有菜单项上显示的选择组件(CheckBox或Radio Button)。如果将该属性值设为all,显示CheckBox组件;如果设为single,显示Radio Button组件;如果设为none,显示正常的菜单项(不显示任何选择组件)。要注意的是,Android SDK官方文档在解释该属性时有一个笔误,原文是:

Whether the items are checkable. Valid values: none, all(exclusive/radiobuttons), single(non-exclusive/checkboxes).

相反了,正确应该是

all(non-exclusive/checkboxes),single(exclusive/radiobuttons).

visible:表示当前组中所有菜单项是否显示。该属性可设置的值是true或false

enable:表示当前组中所有菜单项是否被激活。该属性可设置的值是true或false

3.具体使用

在代码中使用

public boolenonCreateOptionsMenu(Menu menu){

MenuInflatemenuInflate = getMenuInflate();

menuInflate.inflate(R.menu.option_menu,menu);

returntrue;

}

二、使用代码定义Menu

public boolean onCreateOptionsMenu(Menu menu){  

// 方法一,用代码构建   

 menu.add(Menu.NONE, Menu.NONE, 1, "菜单1");  

 menu.add(Menu.NONE, Menu.NONE, 2, "菜单2");  

 menu.add(Menu.NONE, Menu.NONE, 3, "菜单3");  

 menu.add(Menu.NONE, Menu.NONE, 4, "菜单4");  

menu.add(Menu.NONE, Menu.NONE, 5, "菜单5");  

menu.add(Menu.NONE, Menu.NONE, 6, "菜单6");  

return true;  

}  

三、菜单响应

重写onOptionsItemSelected(MenuItem item)这个方法就可以做响应的操作了。

四、实例

res/menu下的activity_main.xml文件


  1. <menu xmlns:android="http://schemas.android.com/apk/res/android" >  
  2.   
  3.     <item  
  4.         android:id="@+id/menu_settings"  
  5.         android:orderInCategory="1"  
  6.         android:icon="@drawable/home"  
  7.         android:title="@string/menu_settings"/>  
  8.     <item  
  9.         android:id="@+id/menu_about"  
  10.         android:orderInCategory="2"  
  11.         android:icon="@drawable/mine"  
  12.         android:title="@string/menu_about"/>  
  13.     <item  
  14.         android:id="@+id/menu_quit"  
  15.         android:orderInCategory="3"  
  16.         android:icon="@drawable/more"  
  17.         android:title="@string/menu_quit"/>  
  18.       
  19. </menu>  

MainActivity.java文件

  1. package com.example.menutest;  
  2.   
  3. import android.os.Bundle;  
  4. import android.app.Activity;  
  5. import android.view.Menu;  
  6. import android.view.MenuItem;  
  7. import android.widget.Toast;  
  8.   
  9. public class MainActivity extends Activity {  
  10.   
  11.     @Override  
  12.     protected void onCreate(Bundle savedInstanceState) {  
  13.         super.onCreate(savedInstanceState);  
  14.         setContentView(R.layout.activity_main);  
  15.     }  
  16.   
  17.     @Override  
  18.     public boolean onCreateOptionsMenu(Menu menu) {  
  19.         // Inflate the menu; this adds items to the action bar if it is present.  
  20.         getMenuInflater().inflate(R.menu.activity_main, menu);  
  21.         return true;  
  22.     }  
  23.   
  24.     @Override  
  25.     public boolean onOptionsItemSelected(MenuItem item) {  
  26.         // TODO Auto-generated method stub  
  27.         switch(item.getItemId()){  
  28.            case R.id.menu_about:             
  29.                Toast.makeText(MainActivity.this""+"关于", Toast.LENGTH_SHORT).show();  
  30.                break;  
  31.            case R.id.menu_settings:  
  32.                  
  33.                Toast.makeText(MainActivity.this""+"设置", Toast.LENGTH_SHORT).show();  
  34.                break;  
  35.            case R.id.menu_quit:  
  36.                  
  37.                Toast.makeText(MainActivity.this""+"退出", Toast.LENGTH_SHORT).show();  
  38.                break;  
  39.            default:  
  40.                break;  
  41.            }  
  42. //         Toast.makeText(MainActivity.this, ""+item.getItemId(), Toast.LENGTH_SHORT).show();  
  43.       
  44.         return super.onOptionsItemSelected(item);  
  45.     }  
  46.   
  47. }  

运行结果:


附:自定义菜单的背景参见:http://blog.csdn.net/sodino/article/details/6165132


不多说,上图,见代码。

 

custom menu background

 

 

 


  1. package lab.sodino.menutest;  
  2. import <a href="http://lib.csdn.net/base/15" class='replace_word' title="Android知识库" target='_blank' style='color:#df3434; font-weight:bold;'>Android</a>.content.Context;  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.os.Handler;  
  6. import android.util.AttributeSet;  
  7. import android.view.InflateException;  
  8. import android.view.LayoutInflater;  
  9. import android.view.Menu;  
  10. import android.view.MenuInflater;  
  11. import android.view.MenuItem;  
  12. import android.view.View;  
  13. import android.widget.Toast;  
  14. /** 
  15.  * @author Sodino E-mail:sodinoopen@hotmail.com 
  16.  * @version Time:2011-1-26 下午04:42:04 
  17.  */  
  18. public class MenuAct extends Activity {  
  19.     @Override  
  20.     public void onCreate(Bundle savedInstanceState) {  
  21.         super.onCreate(savedInstanceState);  
  22.         setContentView(R.layout.main);  
  23.     }  
  24.     public boolean onCreateOptionsMenu(Menu menu) {  
  25.         super.onCreateOptionsMenu(menu);  
  26.         MenuInflater inflater = new MenuInflater(getApplicationContext());  
  27.         inflater.inflate(R.menu.menu, menu);  
  28.         setMenuBackground();  
  29.         return true;  
  30.     }  
  31.     public boolean onOptionsItemSelected(MenuItem item) {  
  32.         String info = "";  
  33.         switch (item.getItemId()) {  
  34.         case R.id.menu_add:  
  35.             info = "Add";  
  36.             break;  
  37.         case R.id.menu_delete:  
  38.             info = "Delete";  
  39.             break;  
  40.         case R.id.menu_home:  
  41.             info = "Home";  
  42.             break;  
  43.         case R.id.menu_help:  
  44.             info = "Help";  
  45.             break;  
  46.         default:  
  47.             info = "NULL";  
  48.             break;  
  49.         }  
  50.         Toast toast = Toast.makeText(this, info, Toast.LENGTH_SHORT);  
  51.         toast.show();  
  52.         return super.onOptionsItemSelected(item);  
  53.     }  
  54.     // 关键代码为重写Layout.Factory.onCreateView()方法自定义布局  
  55.     protected void setMenuBackground() {  
  56.         MenuAct.this.getLayoutInflater().setFactory(new android.view.LayoutInflater.Factory() {  
  57.             /** 
  58.              * name - Tag name to be inflated.<br/> 
  59.              * context - The context the view is being created in.<br/> 
  60.              * attrs - Inflation attributes as specified in XML file.<br/> 
  61.              */  
  62.             public View onCreateView(String name, Context context, AttributeSet attrs) {  
  63.                 // 指定自定义inflate的对象  
  64.                 if (name.equalsIgnoreCase("com.android.internal.view.menu.IconMenuItemView")) {  
  65.                     try {  
  66.                         LayoutInflater f = getLayoutInflater();  
  67.                         final View view = f.createView(name, null, attrs);  
  68.                         new Handler().post(new Runnable() {  
  69.                             public void run() {  
  70.                                 // 设置背景图片  
  71.                                 view.setBackgroundResource(R.drawable.menu_background);  
  72.                             }  
  73.                         });  
  74.                         return view;  
  75.                     } catch (InflateException e) {  
  76.                         e.printStackTrace();  
  77.                     } catch (ClassNotFoundException e) {  
  78.                         e.printStackTrace();  
  79.                     }  
  80.                 }  
  81.                 return null;  
  82.             }  
  83.         });  
  84.     }  
  85. }  

 

 

/res/menu/menu.xml


  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <menu xmlns:android="http://schemas.android.com/apk/res/android">  
  3.     <item android:id="@+id/menu_add" android:title="Add" android:icon="@drawable/menu_add"></item>  
  4.     <item android:id="@+id/menu_delete" android:title="Delete" android:icon="@drawable/menu_delete"></item>  
  5.     <item android:id="@+id/menu_home" android:title="Home" android:icon="@drawable/menu_home"></item>  
  6.     <item android:id="@+id/menu_help" android:title="Help" android:icon="@drawable/menu_help"></item>  
  7. </menu>  

本文内容归CSDN博客博主Sodino所有

转载请注明出处:http://blog.csdn.net/sodino/archive/2011/01/26/6165132.aspx


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值