菜单项onCreateOptionsMenu()和onOptionsItemSelected()的使用

函数onCreateOptionsMenu()为创建Menu菜单的项目

函数onOptionsItemSelected()为处理菜单被选中运行后的事件处理


首先看下Activity的内容:

<span style="font-size:14px;">package com.test.androidtest;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Toast;

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) {
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		super.onOptionsItemSelected(item);
		switch (item.getItemId()) {
		case R.id.menu01:
			Toast.makeText(this, "设置", Toast.LENGTH_LONG).show();
			break;

		case R.id.menu02:
			Toast.makeText(this, "测试", Toast.LENGTH_LONG).show();
			break;
		}
		return true;
	}

}
</span>

R.menu.main文件位于:res/menu下,menu的布局如下:

<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:id="@+id/menu01"
        android:orderInCategory="100"
        android:showAsAction="always"
        android:title="@string/action_settings"/>
    <item
        android:id="@+id/menu02"
        android:orderInCategory="100"
        android:showAsAction="always"
        android:title="test"/>

</menu>

android:showAsAction有never、ifRoom、always、withText等几种值。之处always会一直在右上角显示,如果设置never则看不到,需要点击手机右下角的菜单项才会显示,可以自己试试。


onCreateOptionsMenu()函数下也可以不用布局添加,使用动态添加:

menu.add(0,0,0,"Settings");

menu.add(0,1,1,"test");

return super.onCreateOpntionsMenu(menu);

注:add()四个参数的含义分别为:

第一个参数int类型,group ID,代表组的感念,可以将几个菜单项归为一组,以便更好的以组方式管理菜单按钮。

第二个参数int类型的item ID。这个很重要,代表该项的编号,一个item ID对应一个menu中的选项。在后面使用菜单的时候就靠这个item ID。

第三个参数的int类型Order ID,代表菜单项的现实顺序,默认0,表示菜单的现实顺序就是按照add的显示顺序。

第四个参数String是菜单的标题。

对应的onoOptionsItemSelected()的代码如下:

super.onOptionsItemSelected(item);

switch(item.getItemId()){

    case 0:

             break;

   case 1:

           break;

 }

return true;






Android 开发中,`Fragment` 的 `onCreateOptionsMenu` `onOptionsItemSelected` 是与菜单相关的两个重要生命周期方法,它们的执行时机与 Activity 的菜单机制密切相关。 ### onCreateOptionsMenu 的执行时机 `onCreateOptionsMenu(Menu menu, MenuInflater inflater)` 方法用于向 Activity 提供菜单项。该方法仅在以下条件下会被调用: - Fragment 必须在其 `onCreate()` 方法中调用 `setHasOptionsMenu(true)`,表明该 Fragment 希望参与菜单创建。 - 当宿主 Activity 调用其自身的 `onCreateOptionsMenu(Menu menu)` 时,系统会遍历所有附加的 Fragment,并调用那些设置了 `setHasOptionsMenu(true)` 的 Fragment 的 `onCreateOptionsMenu` 方法。 - 此方法通常只会在菜单第一次被创建时调用一次,例如 Activity 首次显示菜单时[^3]。 示例代码片段如下: ```java @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setHasOptionsMenu(true); // 必须设置为true,才能接收到onCreateOptionsMenu调用 } @Override public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { inflater.inflate(R.menu.fragment_menu, menu); // 加载Fragment专属菜单资源 super.onCreateOptionsMenu(menu, inflater); } ``` ### onOptionsItemSelected 的执行时机 `onOptionsItemSelected(MenuItem item)` 方法用于响应用户点击菜单项的操作事件。该方法在以下情况下执行: - 用户选择了某个菜单项后,系统会首先将事件分发给当前显示的 Fragment。 - 如果 Fragment 的 `onOptionsItemSelected` 返回 `false`,表示该 Fragment 没有处理此菜单项,事件将继续传递给宿主 Activity。 - 只有当 Fragment 的 `setHasOptionsMenu(true)` 被调用且 `onCreateOptionsMenu` 已经执行过的情况下,才可能触发此方法[^1]。 示例代码片段如下: ```java @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == R.id.menu_item_example) { // 处理菜单项点击逻辑 return true; // 表示已处理 } return false; // 未处理,交由Activity处理 } ``` ### 总结 - `onCreateOptionsMenu` 在菜单首次创建时执行一次,前提是 Fragment 明确声明了需要参与菜单构建(通过 `setHasOptionsMenu(true)`)。 - `onOptionsItemSelected` 在每次菜单项被点击时执行,但仅当 Fragment 有机会接收该事件时才会被调用。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值