Android菜单Menu详解

这篇具有很好参考价值的文章主要介绍了Android菜单Menu详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1. 上下文菜单

2. 选项菜单

3. 溢出菜单

4. 弹出菜单-PopupMenu

5. 自定义菜单(菜单项)


菜单资源文件通常放置在res\menu目录下,在创建项目时,默认不自动创建menu目录,所以需手动创建。
Android Resource Directory→ value menu
或在创建根元素<menu></menu>标记的xml文件对自动气建眼
res→Android Resounce File →Resource type→menu
子元素<item></item><group></group>

<menu></menu>标记常用属性,描述:

android: checkableBehavior  用于定义菜单项的选中行为。值可为none(默认值,表示菜单项没有选中状态,无法选择),single(表示只能选择一个菜单项,选择一个菜单项会自动取消其他菜单项的选择状态),all(表示所有菜单项都可以选择,没有互斥的关系)。

<item></item>标记常用属性,描述:

andraid: id  设置ID,也就是唯一标识。
android: title  设置标题。
android: alphabeticShortcut  指定字符快捷键。
android: numericShortcut  指定数字快捷键。
android: enabled  是否可用。
android: checkable  是否可选。
android: visible  是否可见。
android: checked  是否已选用。
android: icon  指定图标,需重写onMenuOpened方法并在其中调用设置显示图标才会在列表项中显示图标(重写方法)。

app: actionLayout  用于设置自定义的菜单项布局。在设置本属性时请不要设置title,可能会导致冲突,可用tools:ignore="MenuTitle"替代title。

app: actionViewClass  用于指定操作按钮的视图类的 XML 属性。值可为"androidx.appcompat.widget.SearchView"(搜索框)等。

app: showAsAction  该属性用于溢出菜单控制菜单项在导航栏上展示位置。值可为:

always  总是在导航栏上显示菜单图标。
ifRoom  如果导航栏右侧有空间,该项就直接显示在导航栏上,不再放入溢出菜单。
never  从不在导航栏上显示,一直放在溢出菜单列表中。
withText  如果能在导航栏上显示,除了显示图标还要显示该项的文字说明。
collapseActionView  操作视图要折叠为一个按钮,点击该按钮再展示操作视图主要用于Searchview

<group></group>标记常用属性,描述:

android: id  为菜单组设置ID。
android: checkableBehavior  指定菜单组选择行为,值可为none(不可选)、all(多选)、single(单选)。
android: menuCategory  对某单组进行分类,指定优先级,值可为containersystemsecondaryalternative
android: enable  指定该菜单组中全部 单项是否可用
android: visible  指定该菜单组中全部某单项是否可见

<item>标记中还可包含<menu>标记,用于显示子菜单。
<group>标记中可有多个<item>标记,用于组成菜单组。

//例
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    
    <item android:title="item1"
        android:icon="@drawable/zerotwo"
        app:showAsAction="always"/>
    <item android:title="item2">
        <menu>
            <item android:title="item2_1"/>
            <item android:title="item2_2"/>
        </menu>
    </item>
    <group>
        <item android:title="item3"/>
        <item android:title="item4"/>
    </group>

</menu>

1. 上下文菜单

长按注册的控件显示菜单。

无法对其列表中菜单项进行自定义布局,使用app:actionLayout属性无效。

public class MainActivity extends AppCompatActivity {

    protected void onCreate(Bundle savedInstanceState) {
        ... ...
        TextView textView=findViewById(R.id.textView);
        registerForContextMenu(textView);
    }

    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        //用于创建菜单(上下文菜单)
        getMenuInflater().inflate(R.menu.test,menu);
    }

    public boolean onContextItemSelected(MenuItem item) {
        //用于选择菜单项(上下文菜单)
        int id=item.getItemId();
        if(id==R.id.~){
            ~
        }
        return true;
    }

}

2. 选项菜单

溢出菜单和选项菜单仅作为操作栏的扩展,无法对其列表中菜单项进行自定义布局,使用app:actionLayout属性无效。

点击标题栏或工具栏最右侧三个点显示菜单

如果隐藏标题栏ActionBar且没有使用工具栏ToolBar(app:menu)将无法使用。

使用ToolBar时要使用 setSupportActionBar( toolBar ) 将工具栏设为操作栏,且为ToolBar的app:menu属性赋值。

public class MainActivity extends AppCompatActivity {

    public boolean onCreateOptionsMenu(Menu menu) {
        //用于创建菜单(选项菜单/溢出菜单)
        MenuInflater menuInflater=getMenuInflater().inflate(R.menu.test,menu);
        return true;
    }

    public boolean onOptionsItemSelected(MenuItem item) {
        //用于选择菜单项(选项菜单/溢出菜单)
        int id=item.getGroupId();
        if(id==R.id.~){
            ~
        }
        return true;
    }

}

3. 溢出菜单

溢出菜单和选项菜单仅作为操作栏的扩展,无法对其列表中菜单项进行自定义布局,使用app:actionLayout属性无效。

溢出菜单和选项菜单并无较大差别,均是点击标题栏ActionBar或工具栏ToolBar最右侧三个点显示菜单
如果隐藏标题栏ActionBar且没有使用工具栏ToolBar(app:menu)将无法使用。

使用ToolBar时要使用 setSupportActionBar( toolBar ) 将工具栏设为操作栏,且为ToolBar的app:menu属性赋值。

菜单栏默认不在某单列表中显示图标;可制作自定义方法来使其显示图标。

//用于使菜单项在列表中显示图片的自定义方法
class MyMenuUtil{
    public static void setOverflowIconVisible(int featureId,Menu menu){
        //ActionBar的featureId是8,ToolBar的featureId是108
        if(featureId%100== Window.FEATURE_ACTION_BAR&&menu!=null){
            if(menu.getClass().getSimpleName().equals("MenuBuilder")){
                try {
                    //setOptionalIconsVisible是隐藏方法,需要反射机制调用。
                    Method m=menu.getClass().getDeclaredMethod("setOptionalIconsVisible",Boolean.TYPE);
                    m.setAccessible(true);
                    m.invoke(menu,true);
                }
                catch (Exception e){
                    e.printStackTrace();
                }
            }
        }
    }
}
public class MainActivity extends AppCompatActivity {

    public boolean onMenuOpened(int featureId, Menu menu) {
        //打开菜单时调用
        //设置在菜单栏中显示图标
        MyMenuUtil.setOverflowIconVisible(featureId,menu);
        return super.onMenuOpened(featureId, menu);
    }

    public boolean onCreateOptionsMenu(Menu menu) {
        //用于创建菜单(溢出菜单/选项菜单)
        MenuInflater menuInflater=getMenuInflater().inflate(R.menu.test,menu);
        return true;
    }

    public boolean onOptionsItemSelected(MenuItem item) {
        //用于选择菜单项(溢出菜单/选项菜单)
        int itemId=item.getItemId();
        int groupId=item.getGroupId();
        if(itemId==R.id.~){
            ~
        }
        return true;
    }
}

4. 弹出菜单-PopupMenu

点击控件触发;效果与上下文菜单类似。

无法对其列表中菜单项进行自定义布局,使用app:actionLayout属性无效。

//触发的控件
Button button=findViewById(R.id.button);
//监听器
button.setOnClickListener(new View.OnClickListener() {
    public void onClick(View view) {
               
        //创建PopupMenu对象,参数为环境、触发控件
        PopupMenu popupMenu=new PopupMenu(MainActivity.this,view);
        //填充菜单
         popupMenu.getMenuInflater().inflate(R.menu.navigation_view_menu,popupMenu.getMenu());
        //为弹出菜单设置菜单项监听器
        popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
            public boolean onMenuItemClick(MenuItem menuItem) {
                //点击菜单项执行
                int menuItemId=menuItem.getItemId();
                return true;
            }
        });
        //展示菜单
        popupMenu.show();
            
    }
});

5. 自定义菜单(菜单项)

部分控件所含菜单的菜单项允许自定义布局,在菜单项中添加app:actionLayout属性即可自定义菜单项布局。在设置本属性时请不要设置title,可能会导致冲突,可用tools:ignore="MenuTitle"替代title。

请注意是app:actionLayout不是android:actionLayout

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto">
 
    <item
        android:id="itemId"
        app:actionLayout="@layout/menu_item_layout"
        tools:ignore="MenuTitle" />

</menu>

设置自定义菜单项中的子控件;使用自定义菜单项时可使用menu.findItem()获取指定菜单项,然后使用getActionView()获取菜单项的View,最后使用view.findViewById()获取指定控件。

//如为自定义菜单项,可进行子控件设置
//例:
Menu menu=view.getMenu();
View menuItemView=menu.findItem(R.id.item1).getActionView();
ImageView imageView=menuItemView.findViewById(R.id.~);
imageView.setImageResource(R.drawable.~);

允许使用自定义菜单项菜单的控件NavigationView(导航控件)。文章来源地址https://www.toymoban.com/news/detail-776091.html

到了这里,关于Android菜单Menu详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Vscode 顶部Menu(菜单)栏消失如何恢复

    首先按一下 Alt按键 ,看一下是否恢复了菜单栏 如果恢复了想了解更进一步的设置,或是没能恢复菜单栏,可以看后续。 1.首先点击左下角 齿轮,打开settings;  或者 直接 ctrl + 逗号  打开settings 2.搜索找到  Menu Bar Visibility 这一项 3.1 设置为 visible 模式 Menu is always visible at th

    2024年04月09日
    浏览(42)
  • el-menu使用递归组件实现多级菜单组件

    vue3+element plus版:点击此处 创建外层菜单 AsideMenu.vue 组件和子菜单项 AsideSubMenu.vue 组件,在 AsideSubMenu 中进行递归操作。 AsideMenu.vue文件内容如下: 判断高亮状态的activeMenu方法中的判断matchPath属性可以让多个路由不同的页面匹配同一个菜单高亮状态,因为菜单高亮状态是根据

    2023年04月12日
    浏览(45)
  • react17+antd4 Menu 点击菜单收起其他展开的所有菜单、页面刷新时设置菜单的选中状态和展开状态

    使用path当作Menu的key. 点击菜单,收起其他展开的所有菜单,只留下一个。 Menu的 onOpenChange 方法:SubMenu 展开/ 关闭的回调函数,展开和回收某项菜单时的事件。 Menu的 openKeys 属性:当前展开的SubMenu菜单项的key数组,当前菜单展开项的key数组。 当前要展开哪一项的openKeys将来是

    2024年04月13日
    浏览(84)
  • Element UI更改下拉菜单el-dropdown-menu样式

    源代码: 这个样式更改还是有点费劲的,如图: 我想更改el-dropdown-item的样式,但是正常覆盖更改无法生效的,从渲染结构可以看出来这个下拉菜单的渲染列表是在文档最底部的。 vue文件新建一个 style样式, 不加scoped; 为保证这个组件的样式 不会影响到其他页面组件样式

    2024年02月09日
    浏览(84)
  • Intellij IDEA菜单栏不见了(Main Menu as Separate Toolbar),恢复菜单栏显示的解决办法

    有人问博主,关于Intellij IDEA菜单栏找不到了,被不小心的操作给隐藏了,怎么办? 这里我先把问题复现一下, Intellij IDEA 的菜单栏隐藏后,如下图: 是不是很慌! 关于这个问题,有两种解决办法, 一种是通过指令, 一种是通过快捷键, 首先看第一种: 通过指令的方式打

    2024年02月01日
    浏览(42)
  • Android 12.0 系统设置显示主菜单添加屏幕旋转菜单实现旋转屏幕功能

     在android12.0的系统rom定制化开发中,在对系统设置进行定制开发中,有产品需求要求增加 旋转屏幕功能的菜单,就是在点击旋转屏幕菜单后弹窗显示旋转0度,旋转 90度,旋转180度, 旋转270度针对不同分辨率的无重力感应的大屏设备的屏幕旋转功能的实现, 接下来就来分析

    2024年02月09日
    浏览(59)
  • react ant-design实现导航菜单menu的路由设置/切换页面

    ant-design版本是5.1.1,路由版本是v6的 新版本的导航菜单路由设置与旧版的不太一样,刚开始的时候甚至不知道该怎么写 实现效果: 代码: 首先,给导航菜单的menu添加点击事件 修改item,通过设置点击事件获取点击后的key值(key值即路由跳转的页面) 打印出来看看 获取到的

    2024年02月12日
    浏览(58)
  • el-menu实现左侧菜单栏(vue2,vue3)

    vue3写法 多级数据 1. home.vue 先把页面基底搭建好 2. Sidebar.vue 左侧菜单栏(多级数据) 3. Header.vue 顶部导航栏 一级数据 home页面是一样的 Sidebar.vue Header.vue(我这里还做了一个切换昼夜间模式的主题) vue2 多级数据 一级数据(使用自己的图标

    2024年02月08日
    浏览(51)
  • Android 之 DrawerLayout (官方侧滑菜单)的简单使用

    本节给大家带来基础UI控件部分的最后一个控件: DrawerLayout ,官方给我们提供的一个侧滑菜单 控件,和上一节的ViewPager一样,3.0以后引入,低版本使用它,需要v4兼容包,说到侧滑,相信 很多人都用过github上的SlidingMenu,不过好像有两个版本,一个是单独的,另一个需要依赖

    2024年02月03日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包