zoukankan      html  css  js  c++  java
  • Android menu

    本讲内容:菜单 menu 
    1、选项菜单 OptionsMenu 
    2、上下文菜单 ContextMenu 
    3、子菜单 SubMenu
    组成Android用户界面的除了View以外,还有菜单和对话框,这一讲我们就共同学习一下菜单的使用。
    菜单是用户界面中最常见的元素,使用也非常频繁,在Android中,菜单被分为如下三种,选项菜单(OptionsMenu)、上下文菜单(ContextMenu)和子菜单(SubMenu),下面分别举例说明。
    一、选项菜单 OptionsMenu
    Android手机上有个Menu按键,当Menu按下的时候,每个Activity都可以选择处理这一请求,在屏幕底部弹出一个菜单,这个菜单我们就叫他选项菜单OptionsMenu,一般情况下,选项菜单最多显示2排每排3个菜单项,这些菜单项有文字有图标,也被称作Icon Menus,如果多于6项,从第六项开始会被隐藏,在第六项会出现一个More里,点击More才出现第六项以及以后的菜单项,这些菜单项也被称作Expanded Menus。
    下面我们通过一个例子来学习选项菜单,重要提示都放在代码注释里了,请留意一下。
    1、新建一个项目 Lesson16_HelloMenu,主Activity叫 MainHelloMenu.java
    2、reslayoutmain.xml的内容如下:
    1. <?xml version="1.0" encoding="utf-8"?>
    2. <linearlayout android:layout_height="fill_parent" android:layout_width="fill_parent" android:background="#003399" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android">
    3.         <textview android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/TextView01" android:text="菜单使用指南" android:layout_margintop="5dp" android:textsize="20sp">
    4.         </textview>
    5.         <textview android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/TextView02" android:text="1、请点击 Menu键呼出选项菜单" android:layout_margintop="5dp" android:textsize="20sp">
    6.         </textview>
    7. </linearlayout>
    复制代码
    3、MainHelloMenu.java的内容如下:
    1. package android.basic.lesson16;
    2. import android.app.Activity;
    3. import android.os.Bundle;
    4. import android.view.Menu;
    5. import android.view.MenuItem;
    6. import android.widget.Toast;
    7. public class MainHelloMenu extends Activity {
    8.         /** Called when the activity is first created. */
    9.         @Override
    10.         public void onCreate(Bundle savedInstanceState) {
    11.                 super.onCreate(savedInstanceState);
    12.                 setContentView(R.layout.main);
    13.         }
    14.         // 点击Menu时,系统调用当前Activity的onCreateOptionsMenu方法,并传一个实现了一个Menu接口的menu对象供你使用
    15.         @Override
    16.         public boolean onCreateOptionsMenu(Menu menu) {
    17.                 /*
    18.                  * add()方法的四个参数,依次是:
    19.                  * 1、组别,如果不分组的话就写Menu.NONE,
    20.                  * 2、Id,这个很重要,Android根据这个Id来确定不同的菜单
    21.                  * 3、顺序,那个菜单现在在前面由这个参数的大小决定
    22.                  * 4、文本,菜单的显示文本
    23.                  */
    24.                 menu.add(Menu.NONE, Menu.FIRST + 1, 5, "删除").setIcon(
    25.                                 android.R.drawable.ic_menu_delete);
    26.                 // setIcon()方法为菜单设置图标,这里使用的是系统自带的图标,同学们留意一下,以
    27.                 // android.R开头的资源是系统提供的,我们自己提供的资源是以R开头的
    28.                 menu.add(Menu.NONE, Menu.FIRST + 2, 2, "保存").setIcon(
    29.                                 android.R.drawable.ic_menu_edit);
    30.                 menu.add(Menu.NONE, Menu.FIRST + 3, 6, "帮助").setIcon(
    31.                                 android.R.drawable.ic_menu_help);
    32.                 menu.add(Menu.NONE, Menu.FIRST + 4, 1, "添加").setIcon(
    33.                                 android.R.drawable.ic_menu_add);
    34.                 menu.add(Menu.NONE, Menu.FIRST + 5, 4, "详细").setIcon(
    35.                                 android.R.drawable.ic_menu_info_details);
    36.                 menu.add(Menu.NONE, Menu.FIRST + 6, 3, "发送").setIcon(
    37.                                 android.R.drawable.ic_menu_send);
    38.                 // return true才会起作用
    39.                 return true;
    40.         }
    41.         //菜单项被选择事件
    42.         @Override
    43.         public boolean onOptionsItemSelected(MenuItem item) {
    44.                 switch (item.getItemId()) {
    45.                 case Menu.FIRST + 1:
    46.                         Toast.makeText(this, "删除菜单被点击了", Toast.LENGTH_LONG).show();
    47.                         break;
    48.                 case Menu.FIRST + 2:
    49.                         Toast.makeText(this, "保存菜单被点击了", Toast.LENGTH_LONG).show();
    50.                         break;
    51.                 case Menu.FIRST + 3:
    52.                         Toast.makeText(this, "帮助菜单被点击了", Toast.LENGTH_LONG).show();
    53.                         break;
    54.                 case Menu.FIRST + 4:
    55.                         Toast.makeText(this, "添加菜单被点击了", Toast.LENGTH_LONG).show();
    56.                         break;
    57.                 case Menu.FIRST + 5:
    58.                         Toast.makeText(this, "详细菜单被点击了", Toast.LENGTH_LONG).show();
    59.                         break;
    60.                 case Menu.FIRST + 6:
    61.                         Toast.makeText(this, "发送菜单被点击了", Toast.LENGTH_LONG).show();
    62.                         break;
    63.                 }
    64.                 return false;
    65.         }
    66.         //选项菜单被关闭事件,菜单被关闭有三种情形,menu按钮被再次点击、back按钮被点击或者用户选择了某一个菜单项
    67.         @Override
    68.         public void onOptionsMenuClosed(Menu menu){
    69.                 Toast.makeText(this, "选项菜单关闭了", Toast.LENGTH_LONG).show();
    70.         }
    71.         //菜单被显示之前的事件
    72.         @Override
    73.         public boolean onPrepareOptionsMenu(Menu menu){
    74.                 Toast.makeText(this, "选项菜单显示之前onPrepareOptionsMenu方法会被调用,你可以用此方法来根据打当时的情况调整菜单", Toast.LENGTH_LONG).show();
    75.                 //如果返回false,此方法就把用户点击menu的动作给消费了,onCreateOptionsMenu方法将不会被调用
    76.                 return true;
    77.         }
    78. }
    复制代码
     
    4、运行程序,检查效果:
     
        
     


     童鞋们可以留意一下Activity的三个和选项菜单相关的方法的使用。5、用xml的方式改写上面的例子,在res中新建一个目录menu,在其中建立一个options_menu.xml,内容如下:
    1. <?xml version="1.0" encoding="utf-8"?>
    2. <menu xmlns:android="http://schemas.android.com/apk/res/android">
    3.         <item android:id="@+id/item01" android:icon="@android:drawable/ic_menu_add" android:title="添加"></item>
    4.         <item android:id="@+id/item02" android:icon="@android:drawable/ic_menu_edit" android:title="编辑"></item>
    5.         <item android:id="@+id/item04" android:icon="@android:drawable/ic_menu_info_details" android:title="详细"></item>
    6.         <item android:id="@+id/item05" android:icon="@android:drawable/ic_menu_delete" android:title="删除"></item>
    7.         <item android:id="@+id/item06" android:icon="@android:drawable/ic_menu_help" android:title="帮助"></item>
    8. </menu>
    复制代码
    6、更改MainHelloMenu.java的onCreateOptionsMenu()方法,内容如下
    1. @Override
    2. public boolean onCreateOptionsMenu(Menu menu) {
    3.         this.getMenuInflater().inflate(R.menu.options_menu, menu);
    4.         return true;
    5. }
    复制代码

    7、再次运行程序查看结果: 

     

     

     
    两种方法比较,个人感觉还是事先定义好菜单的xml比较好,程序代码部分会比较清晰。
     
    http://www.apkbus.com/android-656-1-1.html
     
     
     

    1。普通的Menu

      先来看看最简单的Menu怎样实现。

      在主Activity中覆盖onCreateOptionsMenu(Menu menu)方法。

    复制代码
    代码
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
    // TODO Auto-generated method stub
    menu.add(0, 1, 1, "苹果");
    menu.add(0, 2, 2, "香蕉");
    return super.onCreateOptionsMenu(menu);
    }
    复制代码

    这样就有了两个菜单选项。如果要添加点击事件,则要覆盖onOptionsItemSelected(MenuItem item)方法。

    复制代码
    代码
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
    // TODO Auto-generated method stub
    if(item.getItemId() == 1){
    Toast t = Toast.makeText(this, "你选的是苹果", Toast.LENGTH_SHORT);
    t.show();
    }
    else if(item.getItemId() == 2){
    Toast t = Toast.makeText(this, "你选的是香蕉", Toast.LENGTH_SHORT);
    t.show();
    }
    return true;
    }
    复制代码

    2。SubMenu

      SubMenu的制作也同样简单,在第一段代码onCreateOptionsMenu(Menu menu)方法中加入几句,成下面这样:

    复制代码
    代码
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
    // TODO Auto-generated method stub
    menu.add(0, 1, 1, "苹果");
    menu.add(0, 2, 2, "香蕉");
    SubMenu subMenu = menu.addSubMenu(1, 100, 100, "桃子");
    subMenu.add(2, 101, 101, "大桃子");
    subMenu.add(2, 102, 102, "小桃子");
    return true;
    }
    复制代码

    点击“桃子”后就会出现子菜单,有两个子选项,分别是“大桃子”和“小桃子”。

    3。Context Menu

      类似于电脑上的右键,长按某个View之后弹出来的菜单。

      首先在main.xml里定义若干个按钮。然后覆盖onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo)方法。里面的代码如下:

    首先要注册一下,在onCreate方法里,如下代码:

    复制代码
    代码
    @Override
    public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    b1 = (Button) findViewById(R.id.b1);
    b2 = (Button) findViewById(R.id.b2);
    registerForContextMenu(b1);
    registerForContextMenu(b2);
    }
    复制代码
    复制代码
    代码
    @Override
    public void onCreateContextMenu(ContextMenu menu, View v,
    ContextMenuInfo menuInfo) {
    // TODO Auto-generated method stub
    if(v==b1){
    menu.setHeaderTitle("这是1");
    menu.add(200, 200, 200, "Context Menu 1");
    menu.add(200, 201, 201, "Context Menu 2");
    }
    else if(v==b2){
    menu.setHeaderTitle("这是2");
    menu.add(300, 300, 300, "C 1");
    menu.add(300, 301, 301, "C 2");
    }
    super.onCreateContextMenu(menu, v, menuInfo);
    }
    复制代码

    4。动态Menu

      动态菜单就是根据不同的界面有不同的菜单。下面的代码实现这样的功能:当主界面的某个TextView的值是“M“和“N”时,弹出不同的菜单。

    复制代码
    代码
    @Override
    public boolean onPrepareOptionsMenu(Menu menu) {
    // TODO Auto-generated method stub
    String currentText = tv1.getText().toString();
    if("M".equals(currentText)){
    menu.clear();//先清掉菜单
    MenuItem item = menu.add(0, 400, 401, "to N");//可以通过点击这个菜单项来改变tv1的值这样(变成N)就可以测试了
    item.setIcon(android.R.drawable.alert_dark_frame);//android自带的图标
    }
    if("N".equals(currentText)){
    menu.clear();//先清掉菜单
    MenuItem item = menu.add(0, 401, 402, "to M");//可以通过点击这个菜单项来改变tv1的值这样(变成M)就可以测试了
    item.setIcon(android.R.drawable.alert_light_frame);
    }
    menu.add(0, 402, 403, "Now is " + currentText);//现在共有两个菜单子项
    return super.onPrepareOptionsMenu(menu);
    }
    复制代码

      

    5。用xml文件方式创建Menu

    之前都是用代码的方法创建Menu,用xml配置文件也可以相当方便地制作菜单。

    要res/目录下建一个文件夹,名为menu,下面建一个xml文件,名为menu_xml_file.xml,代码如下:

    复制代码
    代码
    <?xml version="1.0" encoding="utf-8"?>
    <menu xmlns:android="http://schemas.android.com/apk/res/android">
    <group android:id="@+id/grout_main">
    <item android:id="@+id/menu_1"
    android:title="This 1"/>
    <item android:id="@+id/menu_2"
    android:title="This 2" />
    </group>
    </menu>
    复制代码

    在Activity中覆盖onCreateOptionsMenu(Menu menu)方法,代码如下:

    复制代码
    代码
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
    // TODO Auto-generated method stub
    MenuInflater inflater = getMenuInflater();
    inflater.inflate(R.menu.menu_xml_file, menu);
    return true;
    }
    复制代码

    其他的都和在Activity中制作菜单一样。

    http://www.cnblogs.com/giuz/archive/2010/10/19/1855235.html

    另外:http://www.cnblogs.com/salam/archive/2011/04/04/2005329.html  这个讲的也很好

  • 相关阅读:
    c#实现MD5加密
    AJAX学习笔记 一:简单的XMLHTTPRequest示例和asp.net异步更新。
    客户端JS验证fileupload控件,设置只允许特定的文件类型。
    三层架构下的用户登录检测。
    常用用户注册页面客户端验证脚本。
    Android Debug Bridge 技术实现原理
    Android反编译与防止反编译
    android用sharepreference保存输入框中的内容
    android include 控件详解
    android程序排序算法实现
  • 原文地址:https://www.cnblogs.com/xlchen/p/4225785.html
Copyright © 2011-2022 走看看