最近在开发一款音乐播放器,在开发过程中遇到了一点小麻烦,通过android API搞清楚了Menu与ActionBar的爱恨情仇,写了个小Demo祭奠一下那些年我们陷进去的坑,有不对的地方请大神们批评指正。

一.Android系统里的菜单接口(即Menu接口),它是一个父接口,其下又有两个子接口:SubMenu(子菜单)与ContextMenu(上下文菜单)

  常用的菜单有以下三类:Option Menu(选项菜单,常与ActionBar连用),Context Menue(上下文菜单),Popup Menu(弹出框菜单),下面就以小Demo的形式介绍它们的使用方法。

1.Option Menu(选项菜单,常与ActionBar连用)

(1)使用Menu的add()方法,代码生成菜单项

  

/**
* 选项菜单
*/ public class OptionMenuActivity extends ActionBarActivity {
@Override
public void onCreate(Bundle savedInstanceState, PersistableBundle persistentState) {
super.onCreate(savedInstanceState, persistentState);
setContentView(R.layout.activity_menu);
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
//添加菜单项(组ID,当前选项ID,排序,标题)
menu.add(0,100,1,"设置游戏");
menu.add(0,200,2,"开始游戏");
menu.add(0,300,3,"退出游戏");
return super.onCreateOptionsMenu(menu);
} //菜单选项的单击事件处理方法
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
switch (id){
case 100:
Toast.makeText(this,"正在打开设置游戏界面. ..",Toast.LENGTH_LONG).show();
break;
case 200:
Toast.makeText(this,"正在打开开始游戏界面...",Toast.LENGTH_LONG).show();
break;
case 300:
Toast.makeText(this,"正在打开退出游戏界面...",Toast.LENGTH_LONG).show();
break;
default:
break;
}
return super.onOptionsItemSelected(item);
}
}

  效果图如下:

(2)xml文件设置

public class OptionMenuActivity extends AppCompatActivity {
@Override
public void onCreate(Bundle savedInstanceState, PersistableBundle persistentState) {
super.onCreate(savedInstanceState, persistentState);
setContentView(R.layout.activity_menu);
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
//引进菜单布局
getMenuInflater().inflate(R.menu.memu_option,menu);
return super.onCreateOptionsMenu(menu);
} //菜单选项的单击事件处理方法
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
switch (id){
case R.id.game_set:
Toast.makeText(this,"正在打开设置游戏界面. ..",Toast.LENGTH_LONG).show();
break;
case R.id.game_start:
Toast.makeText(this,"正在打开开始游戏界面...",Toast.LENGTH_LONG).show();
break;
case R.id.game_exit:
Toast.makeText(this,"正在打开退出游戏界面...",Toast.LENGTH_LONG).show();
break;
default:
break;
}
return super.onOptionsItemSelected(item);
}
}

  

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".OptionMenuActivity"> <item android:id="@+id/game_set"
android:title="设置游戏"
android:orderInCategory="0"
app:showAsAction="never" />
<item android:id="@+id/game_start"
android:title="开始游戏"
android:orderInCategory="1"
app:showAsAction="never" />
<item
android:id="@+id/game_exit"
android:title="退出游戏"
android:orderInCategory="2"
app:showAsAction="never" />
</menu>

  

效果图如下:

  

注意事项:showAsAction与orderInCategory的作用

  showAsAction主要是针对菜单的显示起作用的,它有三个可选项
    always:总是显示在界面上
    never:不显示在界面上,只让出现在右边的三个点中
    ifRoom:如果有位置才显示,不然就出现在右边的三个点中

orderInCategory="100"(优先级,值越大优先级越低)

showAsAction="always"时的效果:(都未被放到了菜单项中,而是显示到ActionBar上了)

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".OptionMenuActivity"> <item android:id="@+id/game_start"
android:title="开始游戏"
android:orderInCategory="1"
app:showAsAction="always" />
<item android:id="@+id/game_set"
android:title="设置游戏"
android:orderInCategory="0"
app:showAsAction="always" />
<item
android:id="@+id/game_exit"
android:title="退出游戏"
android:orderInCategory="2"
app:showAsAction="always" />
</menu>

showAsAction="ifRoom"时的效果:(退出游戏显示不开被放到了菜单项中)

showAsAction="never"时的效果:(都被放到了菜单项中)

当未设置orderInCategory属性时,菜单列表上的每一项按从上往下的顺序排列:

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".OptionMenuActivity"> <item android:id="@+id/game_start"
android:title="开始游戏"
app:showAsAction="never" />
<item android:id="@+id/game_set"
android:title="设置游戏"
app:showAsAction="never" />
<item
android:id="@+id/game_exit"
android:title="退出游戏"
app:showAsAction="never" />
</menu>

  

当设置orderInCategory属性时,菜单列表上的每一项按优先级排列(优先级从0开始,值越小优先级越高):

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".OptionMenuActivity"> <item android:id="@+id/game_start"
android:title="开始游戏"
android:orderInCategory="1"
app:showAsAction="never" />
<item android:id="@+id/game_set"
android:title="设置游戏"
android:orderInCategory="0"
app:showAsAction="never" />
<item
android:id="@+id/game_exit"
android:title="退出游戏"
android:orderInCategory="2"
app:showAsAction="never" />
</menu>

  效果图如下:

2.Context Menu(上下文菜单)

  (1)简介

  (2)代码实现---ContextMenuActivity.class---menu_context.xml

public class ContextMenuActivity extends AppCompatActivity {

    private TextView changeColor;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_context_menu); changeColor = (TextView) findViewById(R.id.tv_change_color);
//为TextView注册上下文菜单
registerForContextMenu(changeColor);
} @Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
super.onCreateContextMenu(menu, v, menuInfo);
//引入上下文菜单布局
getMenuInflater().inflate(R.menu.memu_context,menu);
} @Override
public boolean onContextItemSelected(MenuItem item) {
int id = item.getItemId();
switch (id){
case R.id.red:
changeColor.setBackgroundColor(Color.RED);
break;
case R.id.blue:
changeColor.setBackgroundColor(Color.BLUE);
break;
case R.id.green:
changeColor.setBackgroundColor(Color.GREEN);
break;
default:
break;
}
return super.onContextItemSelected(item);
}
}

  

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".menu.ContextMenuActivity"> <item android:id="@+id/blue"
android:title="蓝色"
android:orderInCategory="1" /> <item android:id="@+id/red"
android:title="红色"
android:orderInCategory="0" />
<item
android:id="@+id/green"
android:title="绿色"
android:orderInCategory="2" />
</menu>

  (3)效果图:

3.Popup Menu(弹出式菜单)

  (1)简介 

  (2)代码实现---PopupMenuActivity.class---menu_popup.xml

    

public class PopupMenuActivity extends AppCompatActivity {

    private Button btnClick;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_menu_popup); btnClick = (Button) findViewById(R.id.bt_click); } //按钮的点击事件
public void typeSize(View v){
//弹出式按钮
PopupMenu popupMenu =new PopupMenu(this,v);
MenuInflater inflater = popupMenu.getMenuInflater();
inflater.inflate(R.menu.memu_popup,popupMenu.getMenu()); //设置监听事件
popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener(){ @Override
public boolean onMenuItemClick(MenuItem item) {
int id = item.getItemId();
switch (id) {
case R.id.s:
Toast.makeText(PopupMenuActivity.this, "你选择了S号", Toast.LENGTH_LONG).show();
break;
case R.id.m:
Toast.makeText(PopupMenuActivity.this, "你选择了号", Toast.LENGTH_LONG).show();
break;
case R.id.l:
Toast.makeText(PopupMenuActivity.this, "你选择了S号", Toast.LENGTH_LONG).show();
break;
default:
break;
}
return false;
}
}); popupMenu.show();
} }

  

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_context_menu"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.langdon.taiyang.androidtest.menu.PopupMenuActivity"> <Button
android:id="@+id/bt_click"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="点我呀"
android:onClick="typeSize"/> </RelativeLayout>

  

(3)效果

  

    

Menu与ActionBar的爱恨情仇的更多相关文章

  1. web移动端fixed布局和input等表单的爱恨情仇 - 终极BUG,完美解决

    [问题]移动端开发,ios下当fixed属性和输入框input(这里不限于input,只要可以调用移动端输入法的都包括,如:textarea.HTML5中contenteditable等),同时存在的 ...

  2. 注解:大话AOP与Android的爱恨情仇

    转载:大话AOP与Android的爱恨情仇 1. AOP与OOP的区别 平时我接触多的就是OOP(Object Oriented Programming面向对象).AOP(Aspect Oriente ...

  3. 除了love和hate,还能怎么表达那些年的“爱恨情仇”?

    实用英语 帮你全面提高英语水平 关注 童鞋们每次刷美剧的时候,相信都会被CP感满满的男女主角虐得体无完肤吧. 可是,一到我们自己表达爱意或者恨意的时候,却苦于词穷,只会用love, like, hat ...

  4. 对json的爱恨情仇

    本文回想了对json的爱恨情仇. C++有风险,使用需慎重. 本文相关代码在:http://download.csdn.net/detail/baihacker/7862785 当中的測试数据不在里面 ...

  5. String、StringBuilder、StringBuffer的爱恨情仇

    第三阶段 JAVA常见对象的学习 StringBuffer和StringBuilder类 (一) StringBuffer类的概述 (1) 基本概述 下文以StringBuffer为例 前面我们用字符 ...

  6. [转帖]探秘华为(一):华为和H3C(华三)的爱恨情仇史!

    探秘华为(一):华为和H3C(华三)的爱恨情仇史! https://baijiahao.baidu.com/s?id=1620703498823290828&wfr=spider&fo ...

  7. Tidyverse|数据列的分分合合,爱恨情仇

    Tidyverse|数据列的分分合合,爱恨情仇 本文首发于“生信补给站”Tidyverse|数据列的分分合合,一分多,多合一 TCGA数据挖掘可做很多分析,前期数据“清洗”费时费力但很需要. 比如基因 ...

  8. pytorch和tensorflow的爱恨情仇之基本数据类型

    自己一直以来都是使用的pytorch,最近打算好好的看下tensorflow,新开一个系列:pytorch和tensorflow的爱恨情仇(相爱相杀...) 无论学习什么框架或者是什么编程语言,最基础 ...

  9. pytorch和tensorflow的爱恨情仇之定义可训练的参数

    pytorch和tensorflow的爱恨情仇之基本数据类型 pytorch和tensorflow的爱恨情仇之张量 pytorch版本:1.6.0 tensorflow版本:1.15.0 之前我们就已 ...

随机推荐

  1. jQuery之核心API

    1. jQuery.holdReady()方法:暂停或恢复.ready() 事件的执行.在$.holdReady()方法允许调用者延迟jQuery的ready事件.这种先进的功能,通常会被用来允许在 ...

  2. iOS 读取大文件时候的注意点

    转: 使用NSData读取数据,采用NSData的dataWithContentsOfFile:方法.不少人反馈说如果直接使用,将会耗尽iOS的内存. 其实这个是可以改善的. NSData还有一个AP ...

  3. 如何做好PMO,PMO分哪些方面?

    谢邀! 理论的东西,中国PMO大会的帐号说的很全面了. 我分享一些个人感受.失败经验: 我曾帮助中国区COO创立过PMO并且运营两年,COO离职后终止. 成功案例: 我曾看过总部老大们设立Busine ...

  4. 日历插件FullCalendar应用:(一)数据展现

    在博客园逛了很长时间了,它帮助我获得了很多知识,很感谢大家的分享,而自己呢,由于各种纠结一直没提笔写博客,直到我看到了这篇文章http://www.cnblogs.com/zhaopei/p/why_ ...

  5. sift特征源码

    先贴上我对Opencv3.1中sift源码的注释吧,虽然还有很多没看懂.先从detectAndCompute看起 void SIFT_Impl::detectAndCompute(InputArray ...

  6. [Unreal]学习笔记之灯光说明

    利用灯光通道,实现局部照亮效果 没有更改Channel之前的效果: 需要将网格物体设置为可移动 将灯光和被照亮物体的Channel设置为同样并且非0零: 设置成功后,就可以实现局部照亮

  7. ThinkphpCMF笔记

    1.模板js,css文件__PUBLIC__ <link href="__TMPL__Public/style.css" rel="stylesheet" ...

  8. SFDC中的DEBUG

    SFDC的顾问初期,基本都是做一些配置的工作,权限,字段,工作流和审批流之类.那么在这些工作流或者审批流没有按照你预想的来运行而且你检查了多遍后没有找到问题所在的时候.你就需要DEBUG了. 做过开发 ...

  9. redis中的跳跃表

    参考:http://www.leoox.com/?p=347

  10. jsp中超链接路径的写法

    主题 超链接不就是一个地址字符串吗?这能有什么花头? LZSB! 曾经我也是这么想的.... 最近对apache的学习让我对网页中超链接,CSS,js的路径的写法有了一些新的认识. 所以这篇文章主要分 ...