Android控件开发之Menu

 Android系统里面有3种类型的菜单:options menu,context menu,sub menu。

options menu    按Menu键就会显示,用于当前的Activity。
    它包括两种菜单项:
         因为options menu在屏幕底部最多只能显示6个菜单项,这些菜单项称为icon menu,icon menu只支持文字(title) 以及icon,可以设置快捷键,不支持checkbox以及radio控件,所以不能设置checkable选项。
         而多于6的菜单项会以“more” icon menu来调出,称为expanded menu。它不支持icon,其他的特性都和icon menu一样!
 
在Activity里面,一般通过以下函数来使用options menu:
     Activity::onCreateOptionsMenu (Menu menu)       创建options menu,这个函数只会在menu第一次显示时调用。
     Activity::onPrepareOptionsMenu (Menu menu)     更新改变options menu的内容,这个函数会在menu每次显示时调用。
     Activity::onOptionsItemSelected (MenuItem item) 处理选中的菜单项。
 
context menu    要在相应的view上按几秒后才显示的,用于view,跟某个具体的view绑定在一起。
    这类型的菜单不支持icon和快捷键!
 
在Activity里面,一般通过以下函数来使用context menu:
    Activity::registerForContextMenu(View view) 为某个view注册context menu,一般在Activity::onCreate里面调用。
    Activity::onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) 创建context menu,和options menu不同,context meun每次显示时都会调用这个函数。
    Activity::onContextItemSelected(MenuItem item) 处理选中的菜单项。
Activity里面,一般通过以下函数来使用options menu:
     Activity::onCreateOptionsMenu (Menu menu)      创建options menu,这个函数只会在menu第一次显示时调用。
     Activity::onPrepareOptionsMenu (Menu menu)    更新改变options menu的内容,这个函数会在menu每次显示时调用。
     Activity::onOptionsItemSelected (MenuItem item) 处理选中的菜单项。
 
context menu    要在相应的view上按几秒后才显示的,用于view,跟某个具体的view绑定在一起。这类型的菜单不支持icon和快捷键!
 
在Activity里面,一般通过以下函数来使用context menu:
    Activity::registerForContextMenu(View view) 为某个view注册context menu,一般在Activity::onCreate里面调用。
    Activity::onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) 创建context menu,和options menu不同,context meun每次显示时都会调用这个函数。
    Activity::onContextItemSelected(MenuItem item) 处理选中的菜单项。
 
sub menu
    以上两种menu都可以加入子菜单,但子菜单不能嵌套子菜单,这意味着在Android系统,菜单只有两层,设计时需要注意的!同时子菜单不支持icon
 
   
xml形式的menu定义及应用

    上述的三种类型的menu都能够定义为xml资源,但需要手动地使用MenuInflater来得到Menu对象的引用。
      一个菜单,对应一个xml文件,因为要求只能有一个根节点<menu>。官方说<?xml>声明可以不写,但我觉得还是写上好些,很多时候那个<?xml>声明主要是为了声明编码格式utf-8之类的。xml文件保存为res/menu/some_file.xml。Java代码引用资源: R.menu.some_file
 
    接下来介绍相关的节点和属性(所有的属性都定义为android空间内,例如android:icon="@drawable/icon"):
    <menu> 根节点,没有属性。
 
    <group> 表示在它里面的<item>在同一group。相关属性包括:
          id:group id
          menuCategory:        对应 常量Menu CATEGORY_*  — 定义了一组的优先权,有效值:container,system,secondary,和alternative
          orderInCategory:     定义这组菜单在菜单中的默认次序,int值
          checkableBehavior: 这组菜单项是否checkable。有效值:none,all(单选/单选按钮radio button),single(非单选/复选类型checkboxes)
          visible:  这组菜单是否可见 true or false
          enabled:这组菜单是否可用,true or false
 
    <item>  菜单项,可以嵌入<menu>作为子菜单。相关属性包括:
        id:  item id
        menuCategory:         用来定义menu类别
        orderInCategory:      用来定义次序,与一个组在一起(Used to define the order of the item, within a group)
        title:                              标题
        titleCondensed:         标题摘要, 当原标题太长的时候,需要用简短的字符串来代替title
        icon:                              icon 图标
        alphabeticShortcut:  字母快捷键
        numericShortcut:      数学快捷键
        checkable:                  是否为checkbox, true or false
        checked:                     是否设置为checked状态,true or false
        visible:                         是否可见, true or false
        enabled:                      是否可用,true or false

 

        上下文菜单效果

        

        本程序contextmenu.xml源码

        

<?xml version="1.0" encoding="utf-8"?>   
<menu xmlns:android="http://schemas.android.com/apk/res/android">  
<item 
    android:id="@+id/menu_add"
    android:title="@string/menu_add"
    android:checked="true"
    android:checkable="true"/>
     
<group 
    android:id="@+id/group1"       
    android:checkableBehavior="single">                       
    <item 
        android:id="@+id/menu_del"
        android:title="@string/menu_del"
        android:checked="true"/>
    <item 
        android:id="@+id/menu_save"
        android:title="@string/menu_save"/>    
</group>

    <item 
        android:id="@+id/submenu"       
        android:title="子菜单">        
        <menu>          
            <item 
                android:id="@+id/submenuitem1"                
                android:title="menu 1"/>  
            <item 
                android:id="@+id/submenuitem2"
                android:title="menu 2"/>    
        </menu>       
    </item>
    <item 
        android:id="@+id/menu_exit"
         android:title="@string/menu_exit"/>                                   
 </menu>  


  

java源码

 

public class MenuActivity extends Activity 
{
    /** Called when the activity is first created. */

    public static final int ADD_ID   = Menu.FIRST;
    public static final int DELETE_ID  = Menu.FIRST + 1;
    public static final int SAVE_ID  = Menu.FIRST + 2;
    public static final int EXIT_ID  = Menu.FIRST + 3;
    @Override
    public void onCreate(Bundle savedInstanceState)
    {    
		EditText editText = null;

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

		editText = (EditText)findViewById(R.id.edittext);

		//注册上下文菜单
                  this.registerForContextMenu(editText);   
    }
    
    //创建菜单项
    public void onCreateContextMenu(ContextMenu menu, View view, ContextMenu.ContextMenuInfo menuInfo)
    {
		menu.clear();

		super.onCreateContextMenu(menu, view, menuInfo);     
		getMenuInflater().inflate(R.layout.contextmenu, menu);     
    }
    
    //创建菜单项事件
    public boolean onContextItemSelected(MenuItem item) 
    {
    	switch(item.getItemId())   
         {   
			case R.id.menu_add:   
				Toast.makeText(MenuActivity.this, "这是添加", Toast.LENGTH_SHORT).show();   
				break;   
			case R.id.menu_del:   
				Toast.makeText(MenuActivity.this, "这是删除", Toast.LENGTH_SHORT).show();   
				break;   
			case R.id.menu_save:
				Toast.makeText(MenuActivity.this, "这是保存", Toast.LENGTH_SHORT).show();   
				break;
			case R.id.submenuitem1:
				Toast.makeText(MenuActivity.this, "subMenuItem1", Toast.LENGTH_SHORT).show(); 
				break;
			case R.id.submenuitem2:
				Toast.makeText(MenuActivity.this, "subMenuItem2", Toast.LENGTH_SHORT).show(); 
				break;
			case R.id.menu_exit:   
				MenuActivity.this.finish();   
				break;   
         }   
         return true;    
    }
}


默认菜单的两种创建方式 都是通过点击menu键来响应

1、MenuInflater 是用来解析定义在menu 目录下的菜单布局文件的

效果图:

 

menu.xml源码

<?xml version="1.0" encoding="utf-8"?>   
<menu xmlns:android="http://schemas.android.com/apk/res/android">  
    <item 
        android:id="@+id/menu_add"
        android:title="添加"/>      
    <item 
        android:id="@+id/menu_del"
        android:title="删除"/>
    <item 
        android:id="@+id/menu_save"
        android:title="保存"/>
    <item 
        android:id="@+id/menu_exit"
        android:title="退出"/>                                     
 </menu>  


 java源码

public boolean onCreateOptionsMenu(Menu menu)
{      
	//第一种加载方式    
	MenuInflater inflater = getMenuInflater();   

	//设置menu界面为res/menu/menu.xml   
	inflater.inflate(R.menu.menu, menu);   
	return true;   
}
    
public boolean onMenuItemSelected(int featureId, MenuItem item) 
{   
	//得到当前选中的MenuItem的ID   
	int itemId = item.getItemId();   
	switch(itemId)   
	{   
	case R.id.menu_add:   
	    Toast.makeText(MenuActivity.this, "这是添加", Toast.LENGTH_SHORT).show();   
	    break;   
	case R.id.menu_del:   
	    Toast.makeText(MenuActivity.this, "这是删除", Toast.LENGTH_SHORT).show();   
	    break;   
	case R.id.menu_save:
	 	Toast.makeText(MenuActivity.this, "这是保存", Toast.LENGTH_SHORT).show();   
	    break;
	case R.id.menu_exit:   
	 	MenuActivity.this.finish();   
	    break;   
	}   
	return true;   
}   

//第二种加载方式

public static final int ADD_ID        = Menu.FIRST;
public static final int DELETE_ID  = Menu.FIRST + 1;
public static final int SAVE_ID      = Menu.FIRST + 2;
public static final int EXIT_ID        = Menu.FIRST + 3;

public boolean onCreateOptionsMenu(Menu menu)
{
	super.onCreateOptionsMenu(menu);    
	menu.add(0, ADD_ID,     0, R.string.menu_add);    
	menu.add(0, DELETE_ID,  0, R.string.menu_del);  
	menu.add(0, SAVE_ID,    0, R.string.menu_save); 
	menu.add(0, EXIT_ID,    0, R.string.menu_exit);    
	return true; 
}   
  
public boolean onMenuItemSelected(int featureId, MenuItem item) 
{   
	//得到当前选中的MenuItem的ID   
	switch (item.getItemId()) 
	{        
	case ADD_ID: setTitle("Insert...");                 
		break;        
	case DELETE_ID: setTitle("Delete...");                  
	  	break;  
	case SAVE_ID: setTitle("Save...");                  
	  	break;
	case EXIT_ID:                  
	  	finish();                  
	  	break;       
	} 
	
	return super.onOptionsItemSelected(item);

}


 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值