<Android>菜单资源的使用

典型菜单资源结构:<menu>根元素且没有属性,在<menu>根元素里面会嵌套<item>和<group>子元素,<item>里面可以嵌套<menu>形成子菜单。

<group>表示一个菜单组,相同的菜单组可以一起设置其属性,属性说明如下

id:唯一标示该菜单组的引用id

meunCategory:对菜单进行分类,定义菜单的优先级,有效值为container,system,secondary和alternative。

orderInCategory:一个分类排序整数

checkableBehavior:选择行为,单选多选还是其它,有效值为none,all,single

visable:是否可见,true或false

enabled:是否可见,true或false

<item>表示菜单项,包含在<menu>或者<group>中的有效属性,说明如下

id:唯一标示菜单的ID引用

orderInCategory:分类排序

menuCategory:菜单分类

title:菜单标题字符串

titleCondensed:浓缩标题,适合标题太长的时候使用

icon:菜单的图标

alphabeticShortcut:字符快捷键

numericShortcut:数字快捷键

checkable:是否可选

checked:是否已被选中

visible:是否可见

enabled:是否可用

1.菜单xml文件示例file_menu.xml

<?xml version="1.0" encoding="utf-8"?>

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

    <item

       android:title="File"

       android:icon="@drawable/file">

        <menu>

            <group

               android:id="@+id/noncheckable_group"

               android:checkableBehavior="none">

              

                <item

                android:id="@+id/newFile"

                android:title="New"

                android:alphabeticShortcut="n"/>

               

                <item

                android:id="@+id/openFile"

                     android:title="Open"

                     android:alphabeticShortcut="o"/>

                    

                <item

                android:id="@+id/saveFile"

                android:title="Save"

                android:alphabeticShortcut="s"/>

            </group>

        </menu>

    </item>

    <item android:title="Edit" android:icon="@drawable/edit">

        <menu>

            <group android:id="@+id/edit_group"

                    android:checkableBehavior="single">

                   

                <item android:id="@+id/cut"

                      android:title="Cut" />

                     

                <item android:id="@+id/copy"

                      android:title="Copy"/>

                     

                <item android:id="@+id/past"

                      android:title="Past"/>

            </group>

        </menu>

    </item>

    <item android:title="Help" android:icon="@drawable/help">

        <menu>

            <group android:id="@+id/help_group">

                <item android:id="@+id/about"

                        android:title="About" />

                <item android:id="@+id/exit"

                        android:title="Exit" />

            </group>

        </menu>

    </item>

   

</menu>

 

2.java代码中加载菜单

//private MenuInflater mi;

//mi = new MenuInflater(this);

/*

 * 创建菜单

 */

public boolean onCreateOptionsMenu(Menu menu) {

    mi.inflate(R.menu.file_menu, menu);

    return true;

}

//菜单响应

@Override

public boolean onOptionsItemSelected(MenuItem item) {

   switch (item.getItemId()) {

   case R.id.about:

          aboutAlert("本实例演示的是如何使用XML菜单资源来定义菜单!");

          break;

   case R.id.exit:

          exitAlert("真的要退出吗?");

          break;

   }

   return true;

}

// 显示对话框

private void exitAlert(String msg){

   AlertDialog.Builder builder = new AlertDialog.Builder(this);

   builder.setMessage(msg)

          .setCancelable(false)

          .setPositiveButton("确定", new DialogInterface.OnClickListener() {

              public void onClick(DialogInterface dialog, int id) {

                     finish();

              }

          }).setNegativeButton("取消", new DialogInterface.OnClickListener() {

              public void onClick(DialogInterface dialog, int id) {

                     return;

              }

          });

   AlertDialog alert = builder.create();

   alert.show();

}

// 显示对话框

private void aboutAlert(String msg){

   AlertDialog.Builder builder = new AlertDialog.Builder(this);

   builder.setMessage(msg)

          .setCancelable(false)

          .setPositiveButton("确定", new DialogInterface.OnClickListener() {

              public void onClick(DialogInterface dialog, int id) {

              }

          });

   AlertDialog alert = builder.create();

   alert.show();

}

 

直接在java代码中使用

选项菜单

1.覆盖Activity的onCreateOptionsMenu(Menu menu)方法,第一次打开菜单时该方法被自动跳用

2.调用Menu的add()方法添加菜单项(MenuItem),可以调用MenuItem的setIcon()方法设置菜单项图标

3.当菜单项被选择时,覆盖Activity的onOptionsItemSelected()方法来响应事件

public class MainActivity extends Activity {

   private static final int ITEM1 = Menu.FIRST;

   private static final int ITEM2 = Menu.FIRST+1;

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

    }

   /**

    * 覆盖该方法添加菜单项

    */

   public boolean onCreateOptionsMenu(Menu menu) {

          menu.add(0, ITEM1, 0, "开始");

          menu.add(0, ITEM2, 0, "退出");

          return true;

   }

    /**

     * 覆盖该方法,响应菜单选项被单击事件

     */

    public boolean onOptionsItemSelected(MenuItem item) {

       switch (item.getItemId()) {

          case ITEM1:

                 setTitle("开始游戏!");

                 break;

          case ITEM2:

                 setTitle("退出!");

                 break;

          }

       return true;

    }

}

 

上下文菜单

1.覆盖Activity的onCreateContextMenu()方法,调用Menu的add方法添加菜单项(MenuItem).

2.覆盖onContextItemSelected()方法,响应菜单单击事件。

3.调用registerForContextMenu()方法,为视图注册上下文菜单。

public void onCreate(Bundle savedInstanceState) {

   super.onCreate(savedInstanceState);

   setContentView(R.layout.main);

   myTV = (TextView)findViewById(R.id.TextView01);

   registerForContextMenu(myTV);

}

@Override

public void onCreateContextMenu(ContextMenu menu, View v,

          ContextMenuInfo menuInfo) {

   menu.add(0, ITME1, 0, "红色背景");

   menu.add(0, ITME2, 0, "绿色背景");

   menu.add(0, ITME3, 0, "白色背景");

}

@Override

public boolean onContextItemSelected(MenuItem item) {

   switch (item.getItemId()) {

   case ITME1:

          myTV.setBackgroundColor(Color.RED);

          break;

   case ITME2:

          myTV.setBackgroundColor(Color.GREEN);

          break;

   case ITME3:

          myTV.setBackgroundColor(Color.WHITE);

          break;

   }

   return true;

}

 

子菜单

1.覆盖Activity的onCreateOptionsMenu()方法,调用Menu的addSubMenu()方法添加子菜单项(Sub Menu)

2.调用SubMenu的add()方法,添加子菜单(Sub Menu)

3.覆盖onOptionsItemSelected()方法,响应菜单单击事件

public class MainActivity extends Activity {

   private static final int ITEM1 = Menu.FIRST;

   private static final int ITEM2 = Menu.FIRST+1;

  

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

    }

   /**

    * 覆盖该方法添加子菜单项

    */

   public boolean onCreateOptionsMenu(Menu menu) {

          SubMenu file = menu.addSubMenu("文件");

          SubMenu edit = menu.addSubMenu("編輯");

          file.add(0, ITEM1, 0, "新建");

          file.add(0, ITEM2, 0, "打开");

          return true;

   }

    /**

     * 覆盖该方法,响应菜单选项被单击事件

     */

    public boolean onOptionsItemSelected(MenuItem item) {

       switch (item.getItemId()) {

          case ITEM1:

                 setTitle("新建文件!");

                 break;

          case ITEM2:

                 setTitle("打开文件!");

                 break;

          }

       return true;

    }

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。