设为首页 加入收藏

TOP

Android用户界面——菜单menu
2014-11-24 08:37:10 来源: 作者: 【 】 浏览:0
Tags:Android 用户界面 菜单 menu

在android中每个视图组件的创建方式都可以有两种方式:1、通过xml文件及布局文件中声明创建,在布局文件中声明的组件可以通过android:的方式设置其属性。2、就是通过代码的方式在在.java文件中创建。menu组件作为一个视图组件,当然也不例外。在android中,menu被分为三种类型:选项菜单(Optin Menu)、上下文菜单(Context Menu)和子菜单(Sub Menu)


1、选项菜单(Optin Menu)


当用户按下menu键的时候在屏幕上显示的菜单及时所谓的选项菜单,在option menu中屏幕上最多能显示6个。如果超出的话就会在最后一个menu上面显示更多,来显示超过的部分。


Android


下面就来详细看看这个所谓的option menu是怎么实现的,首先在代码文件组中添加如下代码:


package com.ch04;



import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;



public class optionmenu extends Activity {
/** Called when the activity is first created.
* @return */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
public boolean onCreateOptionsMenu(Menu menu) { //增加menu控件的方法直接在.java文件中增加即可。创建一个完整的menu框架。
// TODO Auto-generated method stub
menu.add(0, 1, 1,"Open"); //onCreateOptionsMenu方法中增加的内容,此处有两项一个是增加一个menu_about,一个是增加menu_exit
menu.add(0, 2, 2,"Exit"); //创建的是menu框架中的内容


return super.onCreateOptionsMenu(menu);
}
public boolean onOptionsItemSelected(MenuItem Item){ //当MenuItem被选中时,就覆盖activity的onOptionsItemSelected()来响应事件,
//此处的事件为setTitle()和finish();
/* if(Item.getItemId()==1){
setTitle("start game title");
}else if(Item.getItemId()==3){
finish();
}*/
switch(Item.getItemId()){
case 1:
setTitle("start game title");
break;
case 2:
finish();
break;
}

return super.onOptionsItemSelected(Item);
}

}


run一下,得到运行的程序界面如下


Android


总结一下,创建一个option menu的步骤:


1.覆盖activity的onCreateOptionsMenu(Menu menu)


2.调用add()添加菜单项(MenuItem)


3.当菜单被选择时,就调用响应的事件来覆盖activity的onOptionItemSelected()方法


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Android 启动过程 下一篇Android 获取手机SIM资料详解

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Redis on AWS:Elast (2025-12-27 04:19:30)
·在 Spring Boot 项目 (2025-12-27 04:19:27)
·使用华为开发者空间 (2025-12-27 04:19:24)
·Getting Started wit (2025-12-27 03:49:24)
·Ubuntu 上最好用的中 (2025-12-27 03:49:20)