菜单资源定义可通过 MenuInflater 进行扩充的应用菜单,包括选项菜单、上下文菜单和子菜单。

有关使用菜单的指南,请参阅菜单开发者指南。

文件位置:
res/menu/filename.xml
该文件名将用作资源 ID。
编译后的资源数据类型:
指向 Menu(或其子类)资源的资源指针。
资源引用:
在 Java 中:R.menu.filename
在 XML 中:@[package:]menu.filename
语法:
 
   <?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@[+][package:]id/resource_name"
android:title="string"
android:titleCondensed="string"
android:icon="@[package:]drawable/drawable_resource_name"
android:onClick="method name"
android:showAsAction=["ifRoom" | "never" | "withText" | "always" | "collapseActionView"]
android:actionLayout="@[package:]layout/layout_resource_name"
android:actionViewClass="class name"
android:actionProviderClass="class name"
android:alphabeticShortcut="string"
android:alphabeticModifiers=["META" | "CTRL" | "ALT" | "SHIFT" | "SYM" | "FUNCTION"]
android:numericShortcut="string"
android:numericModifiers=["META" | "CTRL" | "ALT" | "SHIFT" | "SYM" | "FUNCTION"]
android:checkable=["true" | "false"]
android:visible=["true" | "false"]
android:enabled=["true" | "false"]
android:menuCategory=["container" | "system" | "secondary" | "alternative"]
android:orderInCategory="integer" />
<group android:id="@[+][package:]id/resource name"
android:checkableBehavior=["none" | "all" | "single"]
android:visible=["true" | "false"]
android:enabled=["true" | "false"]
android:menuCategory=["container" | "system" | "secondary" | "alternative"]
android:orderInCategory="integer" >
<item />
</group>
<item >
<menu>
<item />
</menu>
</item>
</menu>

  


   
 
元素:
<menu>
必需。该元素必须是根节点。包含 <item> 和/或 <group> 元素。

属性:

xmlns:android
XML 命名空间。必需。定义 XML 命名空间,该命名空间必须为 "http://schemas.android.com/apk/res/android"
<item>
菜单项。可能包含 <menu> 元素(用于子菜单)。必须是 <menu> 或 <group> 元素的子元素。

属性:

android:id
资源 ID。唯一资源 ID。要为此项创建新的资源 ID,请使用以下形式:"@+id/name"。加号表示应将其创建为新 ID。
android:title
字符串资源。字符串资源或原始字符串形式的菜单标题。
android:titleCondensed
字符串资源。字符串资源或原始字符串形式的压缩标题。此标题在正常标题过长的情况下使用。
android:icon
可绘制资源。用作菜单项图标的图片。
android:onClick
方法名称。点击此菜单项时调用的方法。此方法必须在 Activity 中声明为公共方法,并接受 MenuItem 作为其唯一参数,该参数指示所点击的项。此方法优先于对 onOptionsItemSelected() 的标准回调。请参见页面结尾处的示例。

警告:如果您使用 ProGuard(或类似工具)混淆代码,切记不要重命名在此属性中指定的方法,因为这样会破坏功能。

在 API 级别 11 中引入。

android:showAsAction
关键字。指示此项应在应用栏中显示为操作项的时机和方式。菜单项只有在 Activity 包含应用栏时才能显示为操作项。有效值:

说明
ifRoom 只有在应用栏中有空间的情况下,才将此项放置其中。如果没有足够的空间来容纳标记为 "ifRoom" 的所有项,则 orderInCategory 值最低的项会显示为操作,其余项将显示在溢出菜单中。
withText 此外,还会随操作项添加标题文本(由 android:title 定义)。您可以将此值与某个其他值一起作为标记集添加,用竖线 | 分隔。
never 不得将此项放在应用栏中,而应将其列在应用栏的溢出菜单中。
always 始终将此项放在应用栏中。除非此项必须始终显示在操作栏中,否则请勿使用该值。将多个项设置为始终显示为操作项,会导致它们与应用栏中的其他界面重叠。
collapseActionView 与此操作项相关联的操作视图(由 android:actionLayout 或 android:actionViewClass 声明)是可收起的。
在 API 级别 14 中引入。

如需了解详情,请参阅添加应用栏培训课程。

在 API 级别 11 中引入。

android:actionLayout
布局资源。用作操作视图的布局。

如需了解详情,请参阅操作视图和操作提供器

在 API 级别 11 中引入。

android:actionViewClass
类名称。要用作操作视图的 View 的完全限定类名称。例如,"android.widget.SearchView" 表示将使用 SearchView 作为操作视图。

如需了解详情,请参阅操作视图和操作提供器

警告:如果您使用 ProGuard(或类似工具)混淆代码,切记不要重命名在此属性中指定的类,因为这样会破坏功能。

在 API 级别 11 中引入。

android:actionProviderClass
类名称。要用于代替操作项的 ActionProvider 的完全限定类名称。例如,"android.widget.ShareActionProvider" 表示将使用 ShareActionProvider

如需了解详情,请参阅操作视图和操作提供器

警告:如果您使用 ProGuard(或类似工具)混淆代码,切记不要重命名在此属性中指定的类,因为这样会破坏功能。

在 API 级别 14 中引入。

android:alphabeticShortcut
字符。字母快捷键的字符。
android:numericShortcut
整数。数字快捷键的数字。
android:alphabeticModifiers
关键字。菜单项的字母快捷键的辅助键。默认值对应于 Control 键。有效值:

说明
META 对应于 Meta 元键
CTRL 对应于 Control 元键
ALT 对应于 Alt 元键
SHIFT 对应于 Shift 元键
SYM 对应于 Sym 元键
FUNCTION 对应于 Function 元键

注意:您可以在一个属性中指定多个关键字。例如,android:alphabeticModifiers="CTRL|SHIFT" 表示要触发相应的菜单项,用户需要同时按下 Control 和 Shift 元键以及快捷键。

您可以使用 setAlphabeticShortcut() 方法以编程方式设置属性值。要详细了解 alphabeticModifier 属性,请转到 alphabeticModifiers

android:numericModifiers
关键字。菜单项的数字快捷键的辅助键。 默认值对应于 Control 键。有效值:

说明
META 对应于 Meta 元键
CTRL 对应于 Control 元键
ALT 对应于 Alt 元键
SHIFT 对应于 Shift 元键
SYM 对应于 Sym 元键
FUNCTION 对应于 Function 元键

注意:您可以在一个属性中指定多个关键字。例如,android:numericModifiers="CTRL|SHIFT" 表示要触发相应的菜单项,用户需要同时按下 Control 和 Shift 元键以及快捷键。

您可以使用 setNumericShortcut() 方法以编程方式设置属性值。要详细了解 numericModifier 属性,请转到 numericModifiers

android:checkable
布尔值。如果该项可勾选,则为“true”。
android:checked
布尔值。如果默认情况下该项为勾选状态,则为“true”。
android:visible
布尔值。如果默认情况下该项可见,则为“true”。
android:enabled
布尔值。如果默认情况下该项为启用状态,则为“true”。
android:menuCategory
关键字。对应于 Menu CATEGORY_* 常量的值,这些常量用于定义项的优先级。有效值:

说明
container 这类项归属于容器。
system 这类项由系统提供。
secondary 这类项是用户提供的次要(不常用)选项。
alternative 这类项是对当前显示的数据的替代操作。
android:orderInCategory
整数。项在组内的“重要性”顺序。
<group>
一个菜单组,用于创建一组具有相同特征(例如是否可见、是否启用或是否可勾选)的项。包含一个或多个 <item> 元素。必须是 <menu> 元素的子元素。

属性:

android:id
资源 ID。唯一资源 ID。要为此项创建新的资源 ID,请使用以下形式:"@+id/name"。加号表示应将其创建为新 ID。
android:checkableBehavior
关键字。组的可勾选行为类型。有效值:

说明
none 不可勾选
all 可以勾选所有项(使用复选框)
single 只能勾选一项(使用单选按钮)
android:visible
布尔值。如果组可见,则为“true”。
android:enabled
布尔值。如果组为启用状态,则为“true”。
android:menuCategory
关键字。对应于 Menu CATEGORY_* 常量的值,这些常量用于定义组的优先级。有效值:

说明
container 这类组归属于容器。
system 这类组由系统提供。
secondary 这类组是用户提供的次要(不常用)选项。
alternative 这类组是对当前显示的数据的替代操作。
android:orderInCategory
整数。项在类别中的默认顺序。
示例:
保存在 res/menu/example_menu.xml 的 XML 文件:

    <menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item android:id="@+id/item1"
android:title="@string/item1"
android:icon="@drawable/group_item1_icon"
app:showAsAction="ifRoom|withText"/>
<group android:id="@+id/group">
<item android:id="@+id/group_item1"
android:onClick="onGroupItemClick"
android:title="@string/group_item1"
android:icon="@drawable/group_item1_icon" />
<item android:id="@+id/group_item2"
android:onClick="onGroupItemClick"
android:title="@string/group_item2"
android:icon="@drawable/group_item2_icon" />
</group>
<item android:id="@+id/submenu"
android:title="@string/submenu_title"
app:showAsAction="ifRoom|withText" >
<menu>
<item android:id="@+id/submenu_item1"
android:title="@string/submenu_item1" />
</menu>
</item>
</menu>

  


   
 

以下应用代码会通过 onCreateOptionsMenu(Menu) 回调扩充菜单,还会声明其中两个项的点击回调:

java代码:

    public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.example_menu, menu);
return true;
} public void onGroupItemClick(MenuItem item) {
// One of the group items (using the onClick attribute) was clicked
// The item parameter passed here indicates which item it is
// All other menu item clicks are handled by <code><a href="/reference/android/app/Activity.html#onOptionsItemSelected(android.view.MenuItem)">onOptionsItemSelected()</a></code>
} kotlin代码: override fun onCreateOptionsMenu(menu: Menu): Boolean {
menuInflater.inflate(R.menu.example_menu, menu)
return true
} fun onGroupItemClick(item: MenuItem) {
// One of the group items (using the onClick attribute) was clicked
// The item parameter passed here indicates which item it is
// All other menu item clicks are handled by <code><a href="/reference/android/app/Activity.html#onOptionsItemSelected(android.view.MenuItem)">onOptionsItemSelected()</a></code>
}

  


   

Android复习(二)应用资源——>菜单的更多相关文章

  1. Android进阶(二十八)上下文菜单ContextMenu使用案例

    上下文菜单ContextMenu使用案例 前言 回顾之前的应用程序,发现之前创建的选项菜单无法显示了.按照正常逻辑来说,左图中在"商品信息"一栏中应该存在选项菜单,用户可进行分享等 ...

  2. Android <Android应用开发实战> 资源类型<二>

    1.菜单资源菜单不仅可以在onCreateContextMenu或onCreateOptionsMenu方法中通过代码创建,还可以在res/menu目录中建立相应的菜单资源文件,并在上面两个方法中加载 ...

  3. Android进阶(二十六)MenuInflater实现菜单添加

    MenuInflater实现菜单添加 前言 之前实现的Android项目中可以实现菜单的显示.但是再次调试项目时发现此功能已无法实现,很是令人费解.难道是因为自己手机Android系统的问题?尝试通过 ...

  4. Android 打造炫目的圆形菜单 秒秒钟高仿建行圆形菜单

    原文:Android 打造炫目的圆形菜单 秒秒钟高仿建行圆形菜单 转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/43131133, ...

  5. Android:有关下拉菜单导航的学习(供自己参考)

    Android:有关==下拉菜单导航==的学习 因为先前的学习都没想着记录自己的学习历程,所以该博客才那么迟才开始写. 内容: ==下拉菜单导航== 学习网站:android Spinner控件详解 ...

  6. Android 控件 之 Menu 菜单

    http://www.cnblogs.com/Mrs-cc/archive/2012/07/21/2603042.html 1.OptionsMenu (选项菜单)用法总结   使用方法: 方法一:添 ...

  7. 【转】android创建Popwindow弹出菜单的两种方式

    方法一的Activity package com.app.test02; import android.app.Activity; import android.os.Bundle; import a ...

  8. Android进阶(二十)AndroidAPP开发问题汇总(四)

    · Android进阶(二十)AndroidAPP开发问题汇总(四) android:layout_width和android:width的区别 基中的android:layout_width和and ...

  9. Android开发 ---xml构建选项菜单、上下文菜单(长按显示菜单)、发通知、发送下载通知

    1.activity_main.xml 描述: 定义了一个TextView和三个按钮 <?xml version="1.0" encoding="utf-8&quo ...

  10. Android生成二维码--保存和分享二维码图片

    之前写过生成自定义二维码的两篇文章:<Android生成自定义二维码><Android生成二维码–拍照或从相册选取图片>,下面就介绍一下Android应用内如何保存以及分享二维 ...

随机推荐

  1. 【Spring-Security】Re14 Oauth2协议P4 整合SSO单点登陆

    创建一个SSO单点登陆的客户端工程 需要的依赖和之前的项目基本一致: <?xml version="1.0" encoding="UTF-8"?> ...

  2. 位段 -- 内存布局详解C语言

    目录 位段的介绍 位段使用示例: 位段的内存分配 Example 内存分配解析: ## 位段 位段的介绍 位段(二进制位):就是按位存储 位段(bit-field)是C语言中的一种特殊数据类型,它允许 ...

  3. python报错:Pip 20.3+ break proxy connection

    参考: https://www.cnblogs.com/devilmaycry812839668/p/17872452.html =================================== ...

  4. vue前端自适应布局,一步到位所有自适应

    vue前端自适应布局,一步到位所有自适应 页面展示 实现内容 1,左右布局 左侧固定宽带,右侧自适应剩余的宽度. 中间一条分割线,可以拖拉,自适应调整左右侧的宽度. 左侧的高度超长自动出现横向滚动条, ...

  5. OpenTiny HUICharts开源发布,带你了解一个简单、易上手的图表组件库

    摘要:目前 OpenTiny HUICharts 已经成功落地在华为内部100多个产品中,持续提升了用户的可视化体验. 本文分享自华为云社区<OpenTiny HUICharts 正式开源发布, ...

  6. MySQL 优化慢查询

    查询以SELECT 语句的形式执行数据库中的所有查找操作.调整这些语句是重中之重,无论是实现动态网页的亚秒响应时间,还是缩短数小时生成大量夜间报告的时间. 此外SELECT语句,进行查询调谐技术也适用 ...

  7. 【Linux驱动】充电芯片bq24735调试详解

    一.bq24735简介 bq24735 是一款高效率同步电池充电器. 当系统供电需求暂时高于适配器最大供电水平的时候, bq24735 使用智能加速技术来允许电池向系统中释放能量,这样的话将保护适配器 ...

  8. [粉丝问答16]应届生被放鸽子,怒怼HR!找工作和找对象哪个更残酷?

    很多应届生在求职过程中遇到过被放鸽子的情况,但是由于段位不高,资源不够,社会阅历尚浅,很多人都是忍气吐声,但是也不乏有些学生性格刚硬,怒怼的. 比如下面这位学生,竟然直接怼了HR. 0.应届硕士小伙怒 ...

  9. JavaScript设计模式样例十五 —— 状态模式

    状态模式(State Pattern) 定义:创建表示各种状态的对象和一个行为随着状态对象改变而改变的 context 对象.目的:允许对象在内部状态发生改变时改变它的行为,对象看起来好像修改了它的类 ...

  10. zabbix 应用框架分析

    本文通过源码分析,探究zabbix web应用的整体架构,所有分析基于zabbix 3.0.10进行. 总体而言,zabbix web应用使用PHP开发,大量应用OOP方法,主要采用mvc架构,同时包 ...