options menu 按Menu键就会显示,用于当前的Activity。
它包括两种菜单项:
因为options menu在屏幕底部最多只能显示6个菜单项,这些菜单项称为icon menu,icon menu只支持文字(title) 以及icon,可以设置快捷键,不支持checkbox以及radio控件,所以不能设置checkable选项。
而多于6的菜单项会以“more” icon menu来调出,称为expanded menu。它不支持icon,其他的特性都和icon menu一样!
在Activity里面,一般通过以下函数来使用options menu:
Activity::onCreateOptionsMenu (Menu menu) 创建options menu,这个函数只会在menu第一次显示时调用。
Activity::onPrepareOptionsMenu (Menu menu) 更新改变options menu的内容,这个函数会在menu每次显示时调用。
Activity::onOptionsItemSelected (MenuItem item) 处理选中的菜单项。
context menu 要在相应的view上按几秒后才显示的,用于view,跟某个具体的view绑定在一起。
这类型的菜单不支持icon和快捷键!
在Activity里面,一般通过以下函数来使用context menu:
Activity::registerForContextMenu(View view) 为某个view注册context menu,一般在Activity::onCreate里面调用。
Activity::onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) 创建context menu,和options menu不同,context meun每次显示时都会调用这个函数。
Activity::onContextItemSelected(MenuItem item) 处理选中的菜单项。
Activity里面,一般通过以下函数来使用options menu:
Activity::onCreateOptionsMenu (Menu menu) 创建options menu,这个函数只会在menu第一次显示时调用。
Activity::onPrepareOptionsMenu (Menu menu) 更新改变options menu的内容,这个函数会在menu每次显示时调用。
Activity::onOptionsItemSelected (MenuItem item) 处理选中的菜单项。
context menu 要在相应的view上按几秒后才显示的,用于view,跟某个具体的view绑定在一起。这类型的菜单不支持icon和快捷键!
在Activity里面,一般通过以下函数来使用context menu:
Activity::registerForContextMenu(View view) 为某个view注册context menu,一般在Activity::onCreate里面调用。
Activity::onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) 创建context menu,和options menu不同,context meun每次显示时都会调用这个函数。
Activity::onContextItemSelected(MenuItem item) 处理选中的菜单项。
sub menu
以上两种menu都可以加入子菜单,但子菜单不能嵌套子菜单,这意味着在Android系统,菜单只有两层,设计时需要注意的!同时子菜单不支持icon
xml形式的menu定义及应用
上述的三种类型的menu都能够定义为xml资源,但需要手动地使用MenuInflater来得到Menu对象的引用。
一个菜单,对应一个xml文件,因为要求只能有一个根节点<menu>。官方说<?xml>声明可以不写,但我觉得还是写上好些,很多时候那个<?xml>声明主要是为了声明编码格式utf-8之类的。xml文件保存为res/menu/some_file.xml。Java代码引用资源: R.menu.some_file
接下来介绍相关的节点和属性(所有的属性都定义为android空间内,例如android:icon="@drawable/icon"):
<menu> 根节点,没有属性。
<group> 表示在它里面的<item>在同一group。相关属性包括:
id:group id
menuCategory: 对应 常量Menu CATEGORY_* — 定义了一组的优先权,有效值:container,system,secondary,和alternative
orderInCategory: 定义这组菜单在菜单中的默认次序,int值
checkableBehavior: 这组菜单项是否checkable。有效值:none,all(单选/单选按钮radio button),single(非单选/复选类型checkboxes)
visible: 这组菜单是否可见 true or false
enabled:这组菜单是否可用,true or false
<item> 菜单项,可以嵌入<menu>作为子菜单。相关属性包括:
id: item id
menuCategory: 用来定义menu类别
orderInCategory: 用来定义次序,与一个组在一起(Used to define the order of the item, within a group)
title: 标题
titleCondensed: 标题摘要, 当原标题太长的时候,需要用简短的字符串来代替title
icon: icon 图标
alphabeticShortcut: 字母快捷键
numericShortcut: 数学快捷键
checkable: 是否为checkbox, true or false
checked: 是否设置为checked状态,true or false
visible: 是否可见, true or false
enabled: 是否可用,true or false
本程序contextmenu.xml源码
- <?xml version="1.0" encoding="utf-8"?>
- <menu xmlns:android="http://schemas.android.com/apk/res/android">
- <item
- android:id="@+id/menu_add"
- android:title="@string/menu_add"
- android:checked="true"
- android:checkable="true"/>
- <group
- android:id="@+id/group1"
- android:checkableBehavior="single">
- <item
- android:id="@+id/menu_del"
- android:title="@string/menu_del"
- android:checked="true"/>
- <item
- android:id="@+id/menu_save"
- android:title="@string/menu_save"/>
- </group>
- <item
- android:id="@+id/submenu"
- android:title="子菜单">
- <menu>
- <item
- android:id="@+id/submenuitem1"
- android:title="menu 1"/>
- <item
- android:id="@+id/submenuitem2"
- android:title="menu 2"/>
- </menu>
- </item>
- <item
- android:id="@+id/menu_exit"
- android:title="@string/menu_exit"/>
- </menu>
java源码
- public class MenuActivity extends Activity
- {
- /** Called when the activity is first created. */
- public static final int ADD_ID = Menu.FIRST;
- public static final int DELETE_ID = Menu.FIRST + 1;
- public static final int SAVE_ID = Menu.FIRST + 2;
- public static final int EXIT_ID = Menu.FIRST + 3;
- @Override
- public void onCreate(Bundle savedInstanceState)
- {
- EditText editText = null;
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- editText = (EditText)findViewById(R.id.edittext);
- //注册上下文菜单
- this.registerForContextMenu(editText);
- }
- //创建菜单项
- public void onCreateContextMenu(ContextMenu menu, View view, ContextMenu.ContextMenuInfo menuInfo)
- {
- menu.clear();
- super.onCreateContextMenu(menu, view, menuInfo);
- getMenuInflater().inflate(R.layout.contextmenu, menu);
- }
- //创建菜单项事件
- public boolean onContextItemSelected(MenuItem item)
- {
- switch(item.getItemId())
- {
- case R.id.menu_add:
- Toast.makeText(MenuActivity.this, "这是添加", Toast.LENGTH_SHORT).show();
- break;
- case R.id.menu_del:
- Toast.makeText(MenuActivity.this, "这是删除", Toast.LENGTH_SHORT).show();
- break;
- case R.id.menu_save:
- Toast.makeText(MenuActivity.this, "这是保存", Toast.LENGTH_SHORT).show();
- break;
- case R.id.submenuitem1:
- Toast.makeText(MenuActivity.this, "subMenuItem1", Toast.LENGTH_SHORT).show();
- break;
- case R.id.submenuitem2:
- Toast.makeText(MenuActivity.this, "subMenuItem2", Toast.LENGTH_SHORT).show();
- break;
- case R.id.menu_exit:
- MenuActivity.this.finish();
- break;
- }
- return true;
- }
- }
默认菜单的两种创建方式 都是通过点击menu键来响应
1、MenuInflater 是用来解析定义在menu 目录下的菜单布局文件的
menu.xml源码
- <?xml version="1.0" encoding="utf-8"?>
- <menu xmlns:android="http://schemas.android.com/apk/res/android">
- <item
- android:id="@+id/menu_add"
- android:title="添加"/>
- <item
- android:id="@+id/menu_del"
- android:title="删除"/>
- <item
- android:id="@+id/menu_save"
- android:title="保存"/>
- <item
- android:id="@+id/menu_exit"
- android:title="退出"/>
- </menu>
java源码
- public boolean onCreateOptionsMenu(Menu menu)
- {
- //第一种加载方式
- MenuInflater inflater = getMenuInflater();
- //设置menu界面为res/menu/menu.xml
- inflater.inflate(R.menu.menu, menu);
- return true;
- }
- public boolean onMenuItemSelected(int featureId, MenuItem item)
- {
- //得到当前选中的MenuItem的ID
- int itemId = item.getItemId();
- switch(itemId)
- {
- case R.id.menu_add:
- Toast.makeText(MenuActivity.this, "这是添加", Toast.LENGTH_SHORT).show();
- break;
- case R.id.menu_del:
- Toast.makeText(MenuActivity.this, "这是删除", Toast.LENGTH_SHORT).show();
- break;
- case R.id.menu_save:
- Toast.makeText(MenuActivity.this, "这是保存", Toast.LENGTH_SHORT).show();
- break;
- case R.id.menu_exit:
- MenuActivity.this.finish();
- break;
- }
- return true;
- }
- //第二种加载方式
- public static final int ADD_ID = Menu.FIRST;
- public static final int DELETE_ID = Menu.FIRST + 1;
- public static final int SAVE_ID = Menu.FIRST + 2;
- public static final int EXIT_ID = Menu.FIRST + 3;
- public boolean onCreateOptionsMenu(Menu menu)
- {
- super.onCreateOptionsMenu(menu);
- menu.add(0, ADD_ID, 0, R.string.menu_add);
- menu.add(0, DELETE_ID, 0, R.string.menu_del);
- menu.add(0, SAVE_ID, 0, R.string.menu_save);
- menu.add(0, EXIT_ID, 0, R.string.menu_exit);
- return true;
- }
- public boolean onMenuItemSelected(int featureId, MenuItem item)
- {
- //得到当前选中的MenuItem的ID
- switch (item.getItemId())
- {
- case ADD_ID: setTitle("Insert...");
- break;
- case DELETE_ID: setTitle("Delete...");
- break;
- case SAVE_ID: setTitle("Save...");
- break;
- case EXIT_ID:
- finish();
- break;
- }
- return super.onOptionsItemSelected(item);
- }