Android的onCreateOptionsMenu()创建菜单Menu详解-阿里云开发者社区

开发者社区> wei-spring> 正文

Android的onCreateOptionsMenu()创建菜单Menu详解

简介: android一共有三种形式的菜单:             1.选项菜单(optinosMenu)             2.上下文菜单(ContextMenu)             3.子菜单(subMenu) 其中最常用的就是选项菜单(optionsMenu), 该菜单在点击 menu 按键 后会在对应的Activity底部显示出来。
+关注继续查看

android一共有三种形式的菜单: 
            1.选项菜单(optinosMenu) 
            2.上下文菜单(ContextMenu) 
            3.子菜单(subMenu) 
其中最常用的就是选项菜单(optionsMenu), 该菜单在点击 menu 按键 后会在对应的Activity底部显示出来。 
1.Activity菜单机制  (与dialog类似) 
Activity有一套机制来实现对菜单的管理,方法如下:

public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		/**
		 * 此方法用于初始化菜单,其中menu参数就是即将要显示的Menu实例。 返回true则显示该menu,false 则不显示;
		 * (只会在第一次初始化菜单时调用) Inflate the menu; this adds items to the action bar
		 * if it is present.
		 */
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	@Override
	public boolean onPrepareOptionsMenu(Menu menu) {
		/**
		 * 在onCreateOptionsMenu执行后,菜单被显示前调用;如果菜单已经被创建,则在菜单显示前被调用。 同样的,
		 * 返回true则显示该menu,false 则不显示; (可以通过此方法动态的改变菜单的状态,比如加载不同的菜单等) TODO
		 * Auto-generated method stub
		 */
		return super.onPrepareOptionsMenu(menu);
	}

	@Override
	public void onOptionsMenuClosed(Menu menu) {
		/**
		 * 每次菜单被关闭时调用. (菜单被关闭有三种情形,menu按钮被再次点击、back按钮被点击或者用户选择了某一个菜单项) TODO
		 * Auto-generated method stub
		 */
		super.onOptionsMenuClosed(menu);
	}

	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		/**
		 * 菜单项被点击时调用,也就是菜单项的监听方法。 
		 * 通过这几个方法,可以得知,对于Activity,同一时间只能显示和监听一个Menu 对象。 TODO Auto-generated
		 * method stub
		 */
		return super.onOptionsItemSelected(item);
	}

}
 

  

2. 添加菜单: 
       可以在onCreateOptionsMenu或者 onPrepareOptionsMenu方法中来添加菜单

      2.1代码添加: 
        menu.add((int groupId, int itemId, int order, charsequence title) .setIcon(drawable ID)

       add()方法的四个参数,依次是: 

      1、组别,如果不分组的话就写Menu.NONE, 

      2、Id,这个很重要,Android根据这个Id来确定不同的菜单 

      3、顺序,哪个菜单项在前面由这个参数的大小决定 

      4、文本,菜单项的显示文本

       add()方法返回的是MenuItem对象,调用其setIcon()方法,为相应MenuItem设置Icon 
     示例: 
   

 public boolean onCreateOptionsMenu(Menu menu) { 
        super.onCreateOptionsMenu(menu); 
        menu.add(Menu.NONE,  Menu.First+1 , 0, "设置").setIcon(R.drawable.setting); 
        return true; 
    } 

 


       
      2.2布局文件添加: 
          
       getMenuInflater().inflate(R.menu.options_menu, menu); 
      调用Activity的getMenuInflater()得到一个MenuInflater,  
       使用inflate方法来把布局文件中的定义的菜单 加载给 第二个参数所对应的menu对象 
     

  示例: 
     @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
        super.onCreateOptionsMenu(menu); 
        getMenuInflater().inflate( R.menu.options_menu , menu); 
        return true; 
    } 
    布局文件: 
      在res目录下建立一个menu文件夹,并创建布局文件: options_menu.xml  
    <?xml version="1.0" encoding="utf-8"?> 
    <menu xmlns:android="http://schemas.android.com/apk/res/android"> 
    <item android:id=" @+id/menu_setting " android:title="设置" android:icon="@drawable/setting"></item> 
    </menu> 

 


   3.菜单项监听: 
    只要菜单中的菜单项被点击,都会触发onOptionsItemSelected(MenuItem item) 
    item参数即为被点击的菜单项,那么需要在此方法内判断哪个Item被点击了,从而实现不同的操作。 
    对于两种不同的添加菜单方法,判断的方法有一点区别,但本质是一样的。 
    3.1代码添加菜单的判断方法 
    

 @Override 
    public boolean onOptionsItemSelected(MenuItem item) { 
        super.onOptionsItemSelected(item); 
        switch(item.getItemId()) //得到被点击的item的itemId 
        { 
        case  Menu.First+1 :  //对应的ID就是在add方法中所设定的Id 
            break; 
        case  Menu.First+2 : 
            break; 
        } 
        return true; 
    } 

 


  3.2布局文件添加菜单的判断方法: 
  

  @Override 
    public boolean onOptionsItemSelected(MenuItem item) { 
        super.onOptionsItemSelected(item); 
        switch(item.getItemId()) //得到被点击的item的itemId 
        { 
        case  R.id.menu_setting : //这里的Id就是布局文件中定义的Id,在用R.id.XXX的方法获取出来 
            break; 
        case R.id.menu_info: 
            break; 
        } 
        return true; 
    }

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
缓存服务器syns to listen sockets drop导致创建socket失败
问题描述: 最近遇到了一个syn丢包的情况,当系统磁盘、网络、cpu都无压力的时候,系统莫名其妙出现“sync to listen sockets drop”问题;无论带宽是10M还是8G,都会出现这种这种情况。
1749 0
《Java核心技术 卷Ⅱ 高级特性(原书第10版)》一1.7.3 创建Optional值
本节书摘来华章计算机《Java核心技术 卷Ⅱ 高级特性(原书第10版)》一书中的第1章 ,第1.7.3节,[美] 凯S.霍斯特曼(Cay S. Horstmann) 著陈昊鹏 译 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
894 0
创建支持多种屏幕尺寸的Android应用
Android涉及各种各样的支持不同屏幕尺寸和密度的设备。对于应用程序,Android系统通过设备和句柄提供了统一的开发环境,大部分工作是校正每一个应用程序的用户界面到它显示的屏上。与此同时,系统提供APIs允许你控制应用界面为特定的屏幕尺寸和密度,为不同屏幕的配置提供最优化的用户界面设计。
761 0
IntelliJ IDEA 创建 Git 分支并且 Push 到远程
在 IntelliJ 的右下角,你可以看到当前的 Git 分支,然后你可以单击这个分支后,在弹出的界面的最上方有一个新建分支的选项。 然后再弹出的界面中,输入你要创建的分支名称后回车输入。 然后从项目中找到需要的 Git 选项,然后在仓库中选择 Push 在弹出的界面中,你可以看到 PUSH 的选项。
1208 0
Visual Studio 2015中创建C#的Android项目提示"Value cannot be null"的解决方法
原文:Visual Studio 2015中创建C#的Android项目提示"Value cannot be null"的解决方法 选择C# > Android创建一个Blank App时提示如下错误: Value cannot be null. Parameter name: path1 由于之前本机已安装过Android SDK,在安装Visual Studio 2015时跳过了,并没有为Xamarin指定对应路径导致。
954 0
+关注
wei-spring
Android 开发,Java 开发,Python开发
366
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载