optionsMenu就是用户在按下手机键盘上的Menu键时,Activity下方弹出的菜单。借个图展示一下:
接下来,本文的主要内容有:
1、 如何建立菜单
2、 如何响应菜单上的点击动作
3、 讲解Menu的各种属性及Group分组
首先,如何建立菜单。
其实每个Activity都有处理菜单的能力,我们只需要重写onCreateOptionsMenu(Menu menu)这个方法就可以建立菜单了。具体操作起来有两种方法。
方法一,直接用代码构建Menu。
- @Override
- 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;
- }
方法二,先用xml文件构建好Menu,再到代码里加载。
例如,res/menu/option_menu_1.xml内容如下:
- <?xml version="1.0" encoding="utf-8"?>
- <menu
- xmlns:android="http://schemas.android.com/apk/res/android">
- <group android:id="@+id/logined" android:menuCategory="alternative">
- <item android:id="@+id/item1" android:title="菜单1" android:orderInCategory="2" android:icon="@drawable/menu_serach_user"></item>
- <item android:id="@+id/item2" android:title="菜单2" android:orderInCategory="6" android:icon="@drawable/menu_backhome"></item></group>
- <group android:id="@+id/unlogin" android:menuCategory="container">
- <item android:id="@+id/item3" android:title="菜单3" android:orderInCategory="5" android:icon="@drawable/menu_quit"></item>
- <item android:id="@+id/item4" android:orderInCategory="4" android:title="菜单4" android:icon="@drawable/menu_setting_center"></item>
- </group>
- </menu>
则在Activity里这样写:
- @Override
- public boolean onCreateOptionsMenu(Menu menu){
- MenuInflater inflater = getMenuInflater();
- inflater.inflate(R.menu.option_menu_1, menu);
- return true;
- }
其次,如何响应菜单上的点击动作
我们只需要重写onOptionsItemSelected(MenuItem item)这个方法就可以做响应的操作了。代码如下:
- @Override
- public boolean onOptionsItemSelected(MenuItem item){
- Toast.makeText(this, item.getOrder()+","+item.getTitle(), Toast.LENGTH_LONG).show();
- return true;
- }
最后,在设置Menu的时候,有些属性值得一说。
第一个,Item的属性:menuCategory,它的取值一共有四个。我们可以在xml文件中写上android:menuCategory="container",也可以在用代码构建Menu时这样写:menu.add(groupid,itemid,Menu.CATEGORY_CONTAINER,title);四个取值的具体内容可以参见API中Menu的静态属性部分。那这四个分类是有什么用的呢?根据API资料,这个分类应该是跟菜单展示时各项的排序有关系的。但是我试过不同的菜单项设不同的MenuCategory值,但结果并不是预期的那样,预期是:数值越小的越靠上,靠左。但有一点可以确认,MenuCategory不设值(默认为0)时,菜单项是排在最左上角的。
第二个,Item的属性:orderInCategory,它的取值是0-0xffff之间的整数。也是设置排序顺序的。它跟第一个属性有啥关系呢?就是一个菜单项最终的Order值是MenuCategory值与orderInCategory值相加的结果。
还有Group分组,在xml创建Menu时,已经演示了Group的使用。我们使用Group是为了方便处理那些拥有相同特征的菜单项。比如有几个菜单是要登录了才可以使用,或者部分菜单项前面要加选择框,那我们就可以将它们放到一组,后面对这一个组进行操作就行了。
最后再补充一个对Menu进行样式设置的问题。API中没有提供设置背景等的方法。有朋友已经解决了些问题。在此贴上链接。