Android中的基本控件——菜单:Menu

Android中的基本控件——菜单:Menu线性布局 布局管理器 ID 所有组件垂直摆放 布局管理器宽度为屏幕宽度 布局管理器高度为屏幕高度 文本显示组件 组件 ID 程序中使用 组件宽度为文字宽度 组件高度为文字高度 android text 按下 Menu 键出现选项菜单 Override Overridepubl Menumenu 显示菜单

  • 菜单在系统的开发之中是必不可少的一种组件,在Android手机上往往都会存在一个“Menu”的键当选择之后会在屏幕的底部显示系统的菜单,在一个菜单之中可以包含多个菜(MenuItem),在一个菜单之中最多只会显示2排3列的菜单项,如果现在的菜单项超出了6个,则超出部分会自动隐藏,而且会自动出现一个“更多”的菜单项提示用户。
  • 在Android系统之中,菜单一共有三类:选项菜单(OptionsMenu)、上下文(ContextMenu)和子菜单(SubMenu)。

Activity类中定义的菜单操作方法

===================

| 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) | 普通 | 注册上下文菜单 |

Menu接口的常用方法及常量

==============

| 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() | 普通 | 返回菜单项的个数 |

MenuItem接口的常用方法

===============

| 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() | 普通 | 得到菜单中的内容 |

选项菜单:OptionsMenu

================

选项菜单是一个最基本的菜单,也是用户在使用手机时最常见的一种形式,如果要想实现选项菜单,则直接在程序之中覆写android.app.Activity类的如下几个方法:
  • public boolean onCreateOptionsMenu(Menu menu):在此方法之中设置多个菜单项(MenuItem);
  • 返回值:返回true表示显示菜单,反之则不显示;
  • public boolean onOptionsItemSelected(MenuItem item):在此方法之中判断菜单项的操作;
  • public void onOptionsMenuClosed(Menu menu):当菜单关闭时触发此操作;
  • public boolean onPrepareOptionsMenu(Menu menu):在菜单显示前触发此操作;
在main.xml文件之中定义要显示的组件
<?xml version="1.0" encoding="utf-8"?>

<LinearLayout <!-线性布局–>

xmlns:android=“http://schemas.android.com/apk/res/android”

android:id=“@+id/MyLayout” <!-布局管理器ID–>

android:orientation=“vertical” <!-所有组件垂直摆放–>

android:layout_width=“fill_parent” <!-布局管理器宽度为屏幕宽度–>

android:layout_height=“fill_parent”> <!-布局管理器高度为屏幕高度–>

<TextView <!-文本显示组件–>

android:id=“@+id/txt” <!-组件ID,程序中使用–>

android:layout_width=“wrap_content” <!-组件宽度为文字宽度–>

android:layout_height=“wrap_content” <!-组件高度为文字高度–>

android:text=“按下Menu键出现选项菜单”/> <!-默认显示文字–>

定义Activity程序,覆写相应方法以实现菜单的显示

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()

}

}

在配置文件中配置菜单项 —— res/menu/mymenu.xml
<?xml version="1.0" encoding="utf-8"?>

<item

android:id=“@+id/item01”

android:title=“添加”

android:icon=“@android:drawable/ic_menu_add” />

<item android:id=“@+id/item02”

android:title=“保存”

android:icon=“@android:drawable/ic_menu_save” />

<item android:id=“@+id/item03”

android:title=“编辑”

android:icon=“@android:drawable/ic_menu_edit” />

<item android:id=“@+id/item04”

android:title=“详细”

android:icon=“@android:drawable/ic_menu_info_details” />

<item android:id=“@+id/item05”

android:title=“删除”

android:icon=“@android:drawable/ic_menu_delete” />

<item android:id=“@+id/item06”

android:title=“发送”

android:icon=“@android:drawable/ic_menu_send” />

<item android:id=“@+id/item06”

android:title=“帮助”

android:icon=“@android:drawable/ic_menu_help” />

<item android:id=“@+id/item07”

android:title=“发送”

android:icon=“@android:drawable/ic_menu_send” />

MenuInflater
  • 配置文件之中通过“”素定义了多个菜单项,而这些菜单项中的内容与之前的程序代码是一样的,此时如果希望从配置文件之中取出数据,则修改onCreateOptionsMenu()方法,但是在编写此方法的时候需要使用到Activity类中的getMenuInflater()方法先取得MenuInflater类的对象,此类的功能也是将配置文件中定义的组件进行实例化,常用方法如下:

| 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; // 菜单显示

}

上下文菜单:ContextMenu

=================

  • 上下文菜单非常类似于在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程序,显示上下文菜单

上下文菜单非常类似于在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();

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-ZyeLuUgp-27)]

[外链图片转存中…(img-ruF5DB1D-28)]

[外链图片转存中…(img-3pOOUy3T-28)]

[外链图片转存中…(img-yhHRHzAk-29)]

[外链图片转存中…(img-bxFpyv1O-29)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

今天的文章 Android中的基本控件——菜单:Menu分享到此就结束了,感谢您的阅读。
编程小号
上一篇 2025-01-05 23:30
下一篇 2025-01-05 23:27

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ji-chu/102198.html