菜单在的开发之中是必不可少的一种,在android手机上往往都会存在一个“menu”的键当选择之后会在屏幕的底部显示系统的菜单,在一个菜单之中可以包含多个菜(menuitem),在一个菜单之中最多只会显示2排3列的菜单项,如果现在的菜单项超出了6个,则超出部分会自动隐藏,而且会自动出现一个“更多”的菜单项提示用户。
在android系统之中,菜单一共有三类:选项菜单(optionsmenu)、上下文(contextmenu)和子菜单(submenu)。
no. | 方法 | 类型 | 描述 |
---|---|---|---|
1 | public void closecontextmenu() | 普通 | 关闭上下文菜单 |
2 | public void closeoptionsmenu() | 普通 | 关闭选项菜单 |
3 | public void closeoptionsmenu() | 普通 | 设置上下文菜单项 |
4 | public void oncontextmenuclosed(menu menu) | 普通 | 上下文菜单关闭时触发 |
5 | public void oncontextmenuclosed(menu menu) | 普通 | 创建上下文菜单 |
6 | public void oncreatecontextmenu(contextmenu menu,view v,contextmenu.contextmenuinfo menuinfo) | 普通 | 当用户选择“menu”按钮时调用此操作,可以生成一个选项菜单 |
7 | public booleanonmenuitemselected(int featureid, menuitem item) | 普通 | 设置选项菜单项 |
8 | public booleanonoptionsitemselected(menuitem item) | 普通 | 当一个选项菜单中的某个菜单项被选中时触发此操作 |
9 | public void onoptionsmenuclosed(menu menu) | 普通 | 当选项菜单关闭时触发此操作 |
10 | public boolean onprepareoptionsmenu(menu menu) | 普通 | 当选项菜单显示之前操作触发此操作 |
11 | public void openoptionsmenu() | 普通 | 打开选项菜单 |
12 | public menuinflater getmenuinflater() | 普通 | 取得menuinflater类的对象 |
13 | public void registerforcontextmenu(view view) | 普通 | 注册上下文菜单 |
no. | 方法及常量 | 类型 | 描述 |
---|---|---|---|
1 | public static final int first | 常量 | 用于定义菜单项的编号 |
2 | public static final int none | 常量 | 表示菜单不分组 |
3 | public abstract menuitem add(int groupid, int itemid, int order,charsequence title) | 普通 | 此方法用于向菜单之中添加菜单项,参数作用: groupid:菜单所在的组编号; itemid:菜单项的id;order:菜单的出现顺序;title:菜单的显示文字。 |
4 | public abstract menuitem add(int groupid, int itemid, int order, int titleres) | 普通 | 增加菜单项 |
5 | public abstract submenu addsubmenu(int groupid, int itemid, int order, int titleres) | 普通 | 增加子菜单 |
6 | public abstract submenu addsubmenu(int groupid, int itemid, int order, charsequence title) | 普通 | 增加子菜单 |
7 | public abstract void removegroup(int groupid) | 普通 | 删除一个菜单组 |
8 | public abstract void removeitem(int id) | 普通 | 删除一个菜单项 |
9 | public abstract void clear() | 普通 | 清空菜单 |
10 | public abstract void close() | 普通 | 关闭菜单 |
11 | public abstract menuitem getitem(int index) | 普通 | 返回指定的菜单项 |
12 | public abstract int size() | 普通 | 返回菜单项的个数 |
no. | 方法及常量 | 类型 | 描述 |
---|---|---|---|
1 | public abstract int getgroupid() | 普通 | 得到菜单组编号 |
2 | public abstract drawable geticon() | 普通 | 得到菜单项上的图标 |
3 | public abstract int getitemid() | 普通 | 得到菜单项上的id |
4 | public abstract int getorder() | 普通 | 得到菜单项上的编号 |
5 | public abstract submenu getsubmenu() | 普通 | 取得子菜单 |
6 | public abstract charsequence gettitle() | 普通 | 得到菜单项上的标题 |
7 | public abstract boolean ischeckable() | 通 | 判断菜单项是否可用 |
8 | ublic abstract boolean ischecked() | 普通 | 判断此菜单项是否被选中 |
9 | public abstract boolean isenabled() | 普通 | 判断此菜单项是否可用 |
10 | public abstract boolean isvisible() | 普通 | 判断此菜单项是否可见 |
11 | public abstract menuitem setcheckable(boolean checkable) | 普通 | 设置此菜单项是否可用 |
12 | public abstract menuitem setchecked(boolean checked) | 普通 | 设置此菜单项是否默认选中 |
13 | public abstract menuitem setenabled(boolean enabled) | 普通 | 设置此菜单项是否可用 |
14 | public abstract menuitem seticon(drawable icon) | 普通 | 设置此菜单项的图标 |
15 | public abstract menuitem seticon(int iconres) | 普通 | 设置此菜单项的图标 |
16 | public abstract menu itemsetonmenuitemclicklistener (menuitem.onmenuitemclic klistener menuitemclicklistener) | 普通 | 设置此菜单项的监听操作 |
17 | public abstract menuitem settitle(charsequence title) | 普通 | 设置此菜单项的标题 |
18 | public abstract menuitem setvisible(boolean visible) | 普通 | 设置此菜单项是否可见 |
19 | public abstract contextmenu.contextmenuinfo getmenuinfo() | 普通 | 得到菜单中的内容 |
xmlns:android="https://schemas.android.com/apk/res/android" android:id="@+id/mylayout" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> android:id="@+id/txt" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="按下menu键出现选项菜单"/>
package org.lxh.demo; import android.app.activity; import android.os.bundle; import android.view.menu; import android.view.menuitem; import android.widget.toast; public class mymenudemo extends activity { @override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); super.setcontentview(r.layout.main); } @override public boolean oncreateoptionsmenu(menu menu) { // 显示菜单 menu.add(menu.none, // 菜单不分组 menu.first + 1, // 菜单项id 5, // 菜单编号 "删除") // 显示标题 .seticon(android.r.drawable.ic_menu_delete); // 设置图标 menu.add(menu.none, menu.first + 2, 2, "保存").seticon( android.r.drawable.ic_menu_save);// 设置菜单项 menu.add(menu.none, menu.first + 3, 6, "帮助").seticon( android.r.drawable.ic_menu_help);// 设置菜单项 menu.add(menu.none, menu.first + 4, 1, "添加").seticon( android.r.drawable.ic_menu_add); // 设置菜单项 menu.add(menu.none, menu.first + 5, 4, "详细").seticon( android.r.drawable.ic_menu_info_details);// 设置菜单项 menu.add(menu.none, menu.first + 6, 7, "发送").seticon( android.r.drawable.ic_menu_send);// 设置菜单项 menu.add(menu.none, menu.first + 7, 3, "编辑").seticon( android.r.drawable.ic_menu_edit);// 设置菜单项 return true; // 菜单显示 } @override public boolean onoptionsitemselected(menuitem item) { // 选中某个菜单项 switch (item.getitemid()) { // 判断菜单项id case menu.first + 1: toast.maketext(this, "您选择的是“删除菜单”项。", toast.length_long).show(); break; case menu.first + 2: toast.maketext(this, "您选择的是“保存菜单”项。", toast.length_long).show(); break; case menu.first + 3: toast.maketext(this, "您选择的是“帮助菜单”项。", toast.length_long).show(); break; case menu.first + 4: toast.maketext(this, "您选择的是“添加菜单”项。", toast.length_long).show(); break; case menu.first + 5: toast.maketext(this, "您选择的是“详细菜单”项。", toast.length_long).show(); break; case menu.first + 6: toast.maketext(this, "您选择的是“发送菜单”项。", toast.length_long).show(); break; case menu.first + 7: toast.maketext(this, "您选择的是“设置菜单”项。", toast.length_long).show(); break; }return false; }@override public void onoptionsmenuclosed(menu menu) { // 菜单退出时调用 toast.maketext(this, "选项菜单关闭了", toast.length_long).show(); }@override public boolean onprepareoptionsmenu(menu menu) { // 菜单显示前调用 toast.maketext(this,"在菜单显示(oncreateoptionsmenu()方法)之前会调用此操作,可以在此操作之中完成一些预处理操作。",toast.length_long).show(); return true; // 调用oncreateoptionsmenu() } }
no. | 方法 | 类型 | 描述 |
---|---|---|---|
1 | public menuinflater(context context) | 构造 | 创建menuinflater类对象 |
2 | public void inflate(int menures, menu menu) | 普通 | 将配置的资源填充到菜单之中 |
修改oncreateoptionsmenu()`
public boolean oncreateoptionsmenu(menu menu) { // 显示菜单 super.getmenuinflater().inflate(r.menu.mymenu, menu);//填充菜单项 return true; // 菜单显示 }
上下文菜单非常类似于在windows操作系统中的右键菜单的操作形式,在使用支持android操作系统手机时,如果在一个列表显示(listview)操作中,用户可以通过长按操作打开某些操作的菜单,而这种菜单就是上下文菜单,要进行上下文菜单的操作只需要在activity程序之中覆写如下方法即可: public void oncreatecontextmenu(contextmenu menu, view v,contextmenu.contextmenuinfo menuinfo):在此方法之中可以设置所需要显示的所有菜单项; public boolean oncontextitemselected(menuitem item):当某一个菜单项被选中时触发此操作; public void oncontextmenuclosed(menu menu):当菜单项关闭时触发此操作。 定义activity程序,显示上下文菜单 public class mymenudemo extends activity { private string data[] = {"mju", "mju java", "mju 闽江学院", "mju 郑鸿", "mju job"}; // 定义显示的数据 private listview listview;// 定义listview组件 @override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); this.listview = new listview(this) ;// 实例化组件 listview.setadapter(new arrayadapter(this,// 将数据包装 android.r.layout.simple_expandable_list_item_1, // 每行显示一条数据 this.data));// 设置组件内容 super.setcontentview(this.listview);// 将组件添加到屏幕之中 super.registerforcontextmenu(this.listview) ; // 注册上下文菜单 } @override public void oncreatecontextmenu(contextmenu menu, view v, contextmenu.contextmenuinfo menuinfo) {// 显示菜单 super.oncreatecontextmenu(menu, v, menuinfo) ; menu.setheadertitle("信息操作") ; // 设置显示信息头 menu.add(menu.none, menu.first + 1, 1, "添加联系人"); // 设置菜单项 menu.add(menu.none, menu.first + 2, 2, "查看详情"); // 设置菜单项 menu.add(menu.none, menu.first + 3, 3, "删除信息");// 设置菜单项 menu.add(menu.none, menu.first + 4, 4, "另存为");// 设置菜单项 menu.add(menu.none, menu.first + 5, 5, "编辑"); // 设置菜单项 @override public boolean oncontextitemselected(menuitem item) { // 选中某个菜单项 switch (item.getitemid()) {// 判断菜单项id case menu.first + 1: toast.maketext(this, "您选择的是“添加联系人”项。", toast.length_long).show(); break; case menu.first + 2: toast.maketext(this, "您选择的是“查看详情”项。", toast.length_long).show(); break; case menu.first + 3: toast.maketext(this, "您选择的是“删除信息”项。", toast.length_long).show(); break; case menu.first + 4: toast.maketext(this, "您选择的是“另存为”项。", toast.length_long).show(); break; case menu.first + 5: toast.maketext(this, "您选择的是“编辑”项。", toast.length_long).show(); break; } return false; } @override public void oncontextmenuclosed(menu menu) {// 菜单退出时调用 toast.maketext(this, "上下文菜单关闭了", toast.length_long).show(); } }
@override public void oncreatecontextmenu(contextmenu menu, view v, contextmenu.contextmenuinfo menuinfo) {// 显示菜单 super.oncreatecontextmenu(menu, v, menuinfo) ; menu.setheadertitle("信息操作") ; // 设置显示信息头 super.getmenuinflater().inflate(r.menu.mymenu, menu); // 填充菜单项 }
no. | 方法 | 类型 | 描述 |
---|---|---|---|
1 | public abstract menuitem getitem() | 普通 | 得到一个子菜单所属的父菜单对象 |
2 | public abstract submenu setheadericon(int iconres) | 普通 | 设置菜单的显示图标 |
3 | public abstract submenu setheadertitle(int titleres) | 普通 | 设置子菜单的显示标题 |
4 | public abstract submenu setheadertitle(charsequence title) | 普通 | 设置子菜单的显示标题 |
5 | public abstract submenu seticon(int iconres) | 普通 | 设置每个子菜单项的图标 |
public class mymenudemo extends activity { @override public boolean oncreateoptionsmenu(menu menu) { // 显示菜单 submenu filemenu = menu.addsubmenu("文件");// 子菜单 submenu editmenu = menu.addsubmenu("编辑");// 子菜单 filemenu.add(menu.none, menu.first + 1, 1, "新建") ; // 子菜单项 filemenu.add(menu.none, menu.first + 2, 2, "打开") ; // 子菜单项 filemenu.add(menu.none, menu.first + 3, 3, "保存") ; // 子菜单项 editmenu.add(menu.none, menu.first + 4, 4, "撤消");// 子菜单项 editmenu.add(menu.none, menu.first + 5, 5, "恢复");// 子菜单项 return true ; } @override public boolean onoptionsitemselected(menuitem item) {// 选中某个菜单项 switch (item.getitemid()) { // 判断菜单项id case menu.first + 1: toast.maketext(this, "您选择的是“添加联系人”项。", toast.length_long).show(); break; case menu.first + 2: toast.maketext(this, "您选择的是“查看详情”项。", toast.length_long).show(); break; case menu.first + 3: toast.maketext(this, "您选择的是“删除信息”项。", toast.length_long).show(); break; case menu.first + 4: toast.maketext(this, "您选择的是“另存为”项。", toast.length_long).show(); break; case menu.first + 5: toast.maketext(this, "您选择的是“编辑”项。", toast.length_long).show(); break; } return false; } }
定义editmenu的子菜单内容文件—— res/menu/editmenu.xml
@override public boolean oncreateoptionsmenu(menu menu) { // 显示菜单 submenu filemenu = menu.addsubmenu("文件"); // 子菜单 submenu editmenu = menu.addsubmenu("编辑"); // 子菜单 super.getmenuinflater().inflate(r.menu.filemenu, filemenu) ;// 设置菜单项 super.getmenuinflater().inflate(r.menu.editmenu, editmenu) ;// 设置菜单项 return true ; }
如对本文有疑问, 点击进行留言回复!!
Error running app: Default Activity Not Found
如何用HMS Nearby Service给自己的App添加近距离数据传输功能
BlockChain:2020年7月10日世界人工智能大会WAIC《链智未来 赋能产业区块链主题论坛》(四)
网友评论