论坛首页 移动开发技术论坛

Andorid的bug?closeOptionsMenu问题研究

浏览 4144 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2010-02-04  
Activity.closeOptionsMenu()这个方法只能关闭第一层menu,对于二层以上的子菜单submenu,就无能为力。而且据我看到的,Android并没有提供关闭二级菜单的方法或者实现,SubMenu.close()并不能让弹出的submenu消失。目前来看只能通过用户交互,比如点击屏幕的其他部分来实现消失,而这是系统相关。
我个人的想法是,既然submenu建立在menu之上,closeOptionsMenu如果关闭menu,自然也应该把submenu关闭,不知道是我的理解有误还是Android的bug?

我再试试其他方法,看能不能让这个submenu自动消失。
工程代码在下面,有兴趣的可以研究。图片上画圈的是点击处。
package com.hp9016.android.test;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.SubMenu;

public class CloseOptionsMenuActivity extends Activity {

	/** Called when the activity is first created. */
	private final static String TAG = "++++CloseOptionsMenuActivity++++";

	@Override
	public void onCreate(Bundle savedInstanceState) {

		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);

		new Thread() {
			public void run() {
				try {
					Log.d(TAG, "++++run----sleep");
					sleep(30000);
					Log.d(TAG, "++++run----wake");
					closeOptionsMenu();
					Log.d(TAG, "++++closeOptionsMenu");
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			}
		}.start();
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {

		SubMenu sub = menu.addSubMenu(0, 0, 0, R.string.sub_menu).setIcon(
				this.getResources().getDrawable(R.drawable.icon));

		String name = "menuItem1";
		sub.add(0, 0, 0, name);
		name = "menuItem2";
		sub.add(0, 1, 1, name);

		menu.add(0, 1, 1, R.string.menu_item).setIcon(
				this.getResources().getDrawable(R.drawable.icon));

		return super.onCreateOptionsMenu(menu);
	}
}
  • 大小: 57.4 KB
  • 大小: 68 KB
  • 大小: 82.8 KB
   发表时间:2010-02-08  
原因整理如下。看来这个问题比较冷僻,没人鸟~~
1、先说一下二级菜单是个什么东西。看样子就是menu的一个子类,事实上它是一个Dialog。通过log,我们可以看出触发二级菜单的事件是在com.android.internal.policy.impl.PhoneWindow这个类的onSubMenuSelected方法中实现,在这个方法里面有MenuDialogHelper.show(),到MenuDialogHelper才发现二级菜单原来是个AlertDialog。
2、再说为什么closeOptionsMenu不能关闭,我们可以看到其实在二级菜单弹出的时候,option menu也就是按hard key出来的一级菜单已经关闭了,closeOptionsMenu有句注释:If the options menu is already closed, this method does nothing.所以执行这个方法是没有办法关闭二级菜单的。
3、为什么subMenu.close仍然不行呢?跟踪一下,在PhoneWindow的onCloseMenu方法里,它调用closePanel,里面就没有对MenuDialogHelper的处理!因此调用subMenu.close仍然不能关闭二级菜单。其实从onCloseMenu这个方法名我们就可以看出,它的可操作对象仅仅是menu而已。

所以如果想关闭option menu的二级菜单只有两种方法,一是用你的手指头点击屏幕的不相关部分,让系统隐了或者毁了它;还有就得修改android的framework,让它能被非交互型close,也就是调用某种方法让MenuDialogHelper,dismiss掉。这种改法当然影响比较大。
我个人认为这是android对二级菜单设计不合理之处,如果说bug,我也认为不为过。既然把它做成一个Dialog就应该提供或者封装相应的方法让程序员进行合理的操作。关闭仅仅是最基本的吧?
0 请登录后投票
论坛首页 移动开发技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics