Menu与ActionBar的爱恨情仇

最近在开发一款音乐播放器,在开发过程中遇到了一点小麻烦,通过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)效果

  

    

时间: 2024-10-22 06:05:24

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

js 爱恨情仇说 this

原文:js 爱恨情仇说 this this 相信大家在写代码的时候都会遇到,可是怎么样才能用好this,估计这个还是有点困难的,虽然你有时候你会用到,但是他所在的具体的几个场景中所代表的是什么意思了?可能这个你就不是很清楚啊.这个就会在你使用的过程中出现很多的问题,于是今天我们来总结一下this,到底这个this?他真的有想象中的那么难吗? 其实可以总结为一句话:this指的是调用函数的那个对象 于是我们可以总结出this的四个调用场景: (1) 方法模式:简单的说就是使用点表达式或是下标表达式

产品经理和程序员的爱恨情仇

产品经理跪求程序员,程序员跪求程序成功上线! 前几天纯银V在微博上发了一条微博「很多人吐槽“人人都是产品经理”这句话,其实在我看来,这句话的正确理解是“人人都应该学习产品经理的思维方式,来提升自己的专业能力”,不知道作者是否本意如此.当然,实际上它容易被理解为“我也可以做产品经理,创造一个伟大的产品”,那就很扯淡了.尤其水货产品经理的破坏力之强令人惊叹」,引发了诸多讨论. 我看了之后,意味深长的转发了一下:从来没人说人人都是程序员,这其实说明了一些什么……于是又引发了一番热议,比如: 对呀,也不

初识angular.js之爱恨情仇

angular.js Angular.JS 是一组用来开发Web页面的框架.模板以及数据绑定和丰富UI组件.它支持整个开发进程,提供web应用的架构,无需进行手工DOM操作. AngularJS很小,只有60K,兼容主流浏览器,与 jQuery 配合良好. 简单概括:MV*模型的js框架 angular.js之爱恨情仇 爱恋之际 MV*模式 职责清晰.层次分明,例如页面样式变化仅改变View代码,其它层次结构代码无需改动. 数据绑定 数据视图绑定(单.双向数据绑定),无需反锁的改变DOM的值或修

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

[问题]移动端开发,ios下当fixed属性和输入框input(这里不限于input,只要可以调用移动端输入法的都包括,如:textarea.HTML5中contenteditable等),同时存在的时候:两位大侠瞬间发生剧烈的化学反应,出现各种奇葩问题,见下图: [结论]输入框position属性值不是fixed,而变成了absolute [出现情况]当我们唤起键盘的时候,输入框位置不再页面最下面,或者说页面当时还可以继续往下滚动,再或者页面没有滚动到最下边,这个时候就会出现上面的问题 [学习

那些年苹果与 USB 的爱恨情仇

喜新厌旧,人之常情,也是大公司常态. 大公司见异思迁的背后,往往都由利益推动.即使是一个小小的接口,背后都是博弈.像苹果这么傲娇的公司,更是把和USB接口的爱恨情仇演绎得淋漓尽致. 当年,他们曾经是在一起的. 最初Mac和搭载Windows PC的共同接口很少.比如,PC上打印机的接口是并行接口,鼠标和键盘接口是PS/2接口:Mac上的硬盘接口是SCSI接口,鼠标和键盘接口是ADB接口.即使是在调制解调器和外设接口方面,双方都是用的不同接口. 当时的Mac濒临死亡,完全不占优.1998年苹果推出

永和和红薯不得不说的爱恨情仇!

在 2014 年 12 月 24 日这一天下午,@叶秀兰童鞋无意中吐槽了一下自己的毁容事迹,结果,引发出了永和和红薯之间的爱恨情仇,OSCer 们实在是太有才,请慢慢欣赏,如有遗漏,请@小小编辑  告知一二,补上! @叶秀兰:最近毁容部分已经结痂.中午吃完饭,@永和   童鞋不经意的说了一句,你嘴没擦干净... @纠结名字 :@永和  心里想:终于有机会表现了,我要帮她擦嘴.但@叶秀兰  内心一紧,心想:毁容的事被他发现了!眉头一皱,大喊:走开! @chameleon :@永和  恁的一惊,这女

对json的爱恨情仇

本文回想了对json的爱恨情仇. C++有风险,使用需慎重. 本文相关代码在:http://download.csdn.net/detail/baihacker/7862785 当中的測试数据不在里面,由于这是项目开发中用到的,须要保密. 在工作时才接触json,看过简单介绍,语法简单,易于扩展,用起来是非常爽的事.和后端的一些交互也基本上都是用的json.在项目中用了第三方库:simple json,用起来也不亦乐乎.只是也吃过该库的亏: 1.忘了解析后的JSONValue应该delete掉;

一起聊一聊小程序的爱恨情仇

背景 在移动互联网时代,Google和苹果两大巨头推出的Android和ios以及迅雷不及掩耳之势挤掉了曾经的移动端老大哥--诺基亚,然后刮起了pc端到移动端的大浪潮,我也有幸参与到了这次"技术革命"中,在传统的APP时代,每项需求都需要安装APP,越来越多的APP应用即将占满手机存储空间,那么有没有一种软件架构既不需要下载安装,又能够提供像客户端一样流畅友好的用户体验呢?答案是没有的,不过能不能做到接近原生的体验,而又解决不用装更多app的烦恼呢.这类方案中诸如google的PWA(

python 第一天之高级语言与低级语言的爱恨情仇

1高级语言:python java... ... 产生字节码 2低级语言:c  汇编... ... 生成机器码 3低级语言爱着高级语言,因为大部分高级语言都是由低级语言写成的,所以低级语言会帮高级语言把它生成的字节码无条件的转换成机器码,进而交给系统程序,拜托系统程序调用硬件去执行这些机器码. 4高级语言之前在进行着竞争,他们相互比较财力(开发周期)和自身实力(运行速度),结果他们各有千秋,python 财大气粗(库类多),开发周期短,代码量少:JAVA 运行速度相对较快(自身实力),但自身库相