Android Menu 控件 MenuInflater

简介:

我们知道,LayoutInflater是用来实例化整个布局文件,而MenuInflater是用来实例化Menu目录下的Menu布局文件的。

Menu好处:

传统意义上的菜单定义需要Override Activity的onCreateOptionsMenu,然后在里面调用Menu.add把Menu的一个个item加进来,比较复杂。而通过使用MenuInflater可以把Menu的构造直接放在Menu布局文件中,真正实现模型(Model)与视图(View)的分离,程序也看着清爽多了。

样例:

下面一个实例是定义四个菜单,并且实现了一个菜单事件, 当我们点击设置(Settind)菜单,进入手机设置状态。

效果图如下:

源代码如下:

/TestMenuInflater/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_add"  
        android:title="Add"  
        android:icon="@android:drawable/ic_menu_add"/>  
     <item   
        android:id="@+id/menu_wallaper"  
        android:title="Wallpaper"  
        android:icon="@android:drawable/ic_menu_gallery"/>  
    <item   
        android:id="@+id/menu_search"  
        android:title="Search"  
        android:icon="@android:drawable/ic_search_category_default"/>  
    <item   
        android:id="@+id/menu_setting"  
        android:title="Settings"  
        android:icon="@android:drawable/ic_menu_preferences"/>  
</menu>  

TestMenuInflater.java:

package com.android.test;  
import android.app.Activity;  
import android.content.Intent;  
import android.os.Bundle;  
import android.view.Menu;  
import android.view.MenuInflater;  
import android.view.MenuItem;  
public class TestMenuInflater extends Activity {  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
    }  
      
    @Override  
    public boolean onCreateOptionsMenu(Menu menu) {  
        MenuInflater inflater = getMenuInflater();  
        inflater.inflate(R.menu.options_menu, menu);      
        return true;  
    }  
      
    @Override  
    public boolean onOptionsItemSelected(MenuItem item) {  
        switch (item.getItemId()) {  
        case R.id.menu_add:  
            break;  
        case R.id.menu_wallaper:  
            break;  
        case R.id.menu_search:  
            break;  
        case R.id.menu_setting:  
            showSettings();  
            break;  
        }  
        return super.onOptionsItemSelected(item);  
    }  
      
      
    private void showSettings(){  
          
     final Intent settings = new Intent(android.provider.Settings.ACTION_SETTINGS);  
     settings.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK |  
             Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);  
              
     startActivity(settings);  
   }  
}  

几点说明:

  1. 与LayoutInflater相比,MenuInflater的用法简单多了。首先,MenuInflater获取方法只有一种:Activity.getMenuInflater();其次,MenuInflater.inflater(int menuRes,Menu menu)(这里不代表inflater就是static方法,可以这样调用,只是为了描述方便)的返回值是void型,这就决定了MenuInflater.inflater后就没有后续操作了。这说明通过这种方式把Menu布局文件写好后就不能在程序中动态修改了,而不像LayoutInflater.inflater那样,返回值是View型,可以进行后续的进一步操作。另外,MenuInflater只有一个void inflater(int menuRes,Menu menu)非构造方法。
  2. Menu布局文件中的icon资源是Android自带的,通过“@android:drawable/"获取到。
  3. 另外,Android也有类似的功能。具体参考源码:/packages/apps/Launcher/src/com/android/launcher/Launcher.java
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恋恋西风

up up up

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值