Android_Menu

一.Menu简介
Android系统里面有3种类型的菜单:options menu,context menu,sub menu。
android.view.Menu接口代表一个菜单,android用它来管理各种菜单项。注意一般情况下不自己创建menu,因为每个Activity默认都自带了一个,我们要做的是为它加菜单项和响应菜单项的点击事件。android.view.MenuItem代表每个菜单项,android.view.SubMenu代表子菜单!
Android_Menu_第1张图片
Menu,MenuItem和SubMenu关系图

每个activity包含一个菜单,一个菜单又能包含多个菜单项和多个子菜单,子菜单其实也是菜单(因为它实现了Menu接口),因此子菜单也可以包含多个菜单项。SubMenu继承了Menu的addSubMenu()方法,但调用时会抛出运行时错误。OnCreateOptionsMenu()和OnOptionsMenuSelected()是activity中提供了两个回调方法,用于创建菜单项和响应菜单项的点击。


1.options menu    
按Menu键就会显示,用于当前的Activity。

它包括两种菜单项:
    (1)因为options menu在屏幕底部最多只能显示6个菜单项,这些菜单项称为icon menu,icon menu只支持文字(title) 以及icon,可以设置快捷键,不支持checkbox以及radio控件,所以不能设置checkable选项。
    (2)而多于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) 处理选中的菜单项。

2.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) 处理选中的菜单项。
 
3.sub menu
    以上两种menu都可以加入子菜单,但子菜单不能嵌套子菜单,这意味着在Android系统,菜单只有两层,设计时需要注意的!同时子菜单不支持icon。

二.Menu的使用

1.创建options menu和响应菜单项

andriod activity已经为我们创建好了menu对象,并提供了回调的方法onCreateOptionsMenu(Menu menu)来初始化菜单,该方法只会在选项菜单第一次显示的时候创建,如果需要改动菜单的内容,要调用onPrepareOptionsMenu(Menu)方法。
注意:
如果设备上没有物理上的Menu键,就会显示overflow按钮(就是title上面的三个点),这个本身android的设计就是这样的。
响应菜单项有两种方式:
1.通过重写onOptionsItemSelected方法来响应菜单项的点击事件
2.通过监听器来响应菜单项的点击事件android文档对onMenuItemClick(MenuItem item)回调方法的说明是"Called when a menu item has been invoked. This is the first code that is executed; if it returns true, no other callbacks will be executed." 可见该方法先于onOptionsItemSelected执行

效果图:

代码:

2.创建和响应子菜单
效果图:
代码:

2.xml形式Menu的使用

三种类型的menu都能够定义为xml资源,需要手动地使用MenuInflater来得到Menu对象的引用。
    一个菜单,对应一个xml文件,因为要求只能有一个根节点<menu>。xml文件保存在res/menu/目录中
    
相关的节点和属性
    <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

你可能感兴趣的:(Android_Menu)