Android实现选项菜单子菜单

Android之选项菜单和子菜单学习笔记,供大家参考,具体内容如下

菜单简介:

菜单在桌面应用中使用十分广泛,几乎所有的桌面应用都有菜单。但是随着手机的发展,对于手机桌面菜单的使用减少了很多,一般来说我们把菜单都放到应用中是实现,桌面应用的菜单与手机应用的菜单的不同之处就是,桌面菜单一般可见,而手机不可见,通常需要用户按下手机上的MENU键时,才会弹出菜单的相关应用,这里简单的来说下菜的简单使用情况,通过一个小案例来讲解。

一般菜单的创建有两种方式,一种是在Java代码中创建,一种是在XML中创建,本次主要讲解XML中创建菜单的案例,因为一般推荐使用的都是XML方式来创建菜单,相比Java代码,他更便于维护,可扩展性强,耦合度底。

案例实现,用户输入文字,可以通过菜单选择字体的大小,字体的颜色等

实现步骤:

1.首先在资源文件夹的menu下创建菜单xml

menu_main.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
 <item
  android:id="@+id/menuFont"
  android:title="字体大小">
  <menu>
   <group
    android:id="@+id/groupFont"
    android:checkableBehavior="none">
    <item
     android:id="@+id/font_10"
     android:title="10" />
    <item
     android:id="@+id/font_12"
     android:title="12" />
    <item
     android:id="@+id/font_14"
     android:title="14" />
    <item
     android:id="@+id/font_16"
     android:title="16" />
    <item
     android:id="@+id/font_18"
     android:title="18" />
   </group>
  </menu>
 </item>

 <item
  android:id="@+id/menuColor"
  android:icon="@mipmap/ic_launcher"
  android:title="字体颜色">
  <menu>
   <group
    android:id="@+id/groupColor"
    android:checkableBehavior="none">
    <item
     android:id="@+id/red"
     android:title="红色" />
    <item
     android:id="@+id/blue"
     android:title="蓝色" />
    <item
     android:id="@+id/green"
     android:title="绿色" />
   </group>
  </menu>
 </item>
</menu>

对于上面的xml文件中:

‘<'item …/>元素:定义菜单项。
‘<'group…/>子元素:将多个'<'item…/>定义的菜单项包装成一个菜单组,'<'gruop…/>
子元素用于控制整组菜单的行为,该元素可指定如下的常用属性:

  • checkableBehavior:指定该组菜单的选择行为。可以指定为none(不可选)、
  • all(多选)和single(单选)三个值
  • menuCategory:对菜单进行分类,指定菜单的优先级。有效值为container、
  • system、secondary和alternative
  • visible:指定该组件菜单是否可见。
  • enable:指定该组菜单是否可用。

一般'<'item .../>元素用于定义菜单项,'<'item .../>元素又可包含'<'menu.../>元素,位
于'<'item.../>元素内部的'<'menu.../>就是他的子菜单。

对于'<'item…/>元素可用指定如下常用属性:

android:id: 为菜单项指定一个唯一的标识 
android:title: 指定菜单项的标题
android:icon: 指定菜单项的图标
android:alphabeticShortcut: 为菜单项指定字符快捷键 
android:numericShortcut: 为菜单项指定数字快捷键 
android:checkable: 设置该次啊单项是否可选 
android:checked: 设置该菜单项是否已选中 
android:visible: 设置该菜单项是否可见 
android:enable: 设置该菜单项是否可用

2.设置与菜单项关联的Activity,在activity中重写onCreateOptionsMenu(Menu menu)、
如果需要菜单项的监听事件,则需要重写

onOptionsItemSelected(MenuItem item)

MainActivity.java

public class MainActivity extends AppCompatActivity {

private EditText mEdt;
private TextView mTv;

@Override
protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 mEdt = (EditText) findViewById(R.id.mEdt);
 mTv = (TextView) findViewById(R.id.mInput);
}

/**
 * 通过该方法添加菜单项或子菜单项
 * @param menu
 * @return
 */
@Override
public boolean onCreateOptionsMenu(Menu menu) {
 //方式一添加菜单布局
 MenuInflater inflater = new MenuInflater(this);
 //将解析到的布局添加到menu中
 inflater.inflate(R.menu.menu_main, menu);
 //方式二添加菜单布局
// getMenuInflater().inflate(R.menu.menu_main,menu);
 return super.onCreateOptionsMenu(menu);
}

/**
 * 设置菜单项的点击事件
 * @param item
 * @return
 */
@Override
public boolean onOptionsItemSelected(MenuItem item) {

 switch (item.getItemId()) {
  case R.id.menuColor:
   Toast.makeText(this, "你选择了修改颜色", Toast.LENGTH_SHORT).show();
   break;
  case R.id.menuFont:
   Toast.makeText(this, "你选择了修改字体", Toast.LENGTH_SHORT).show();
   break;
 }
 return super.onOptionsItemSelected(item);
 }
}

基本的布局就是这样了,看看整体布局

字体大小下的子菜单:

字体颜色下的子菜单:

3.开始实现功能了,这里我只贴上功能实现的方法:onOptionsItemSelected(MenuItem item)

@Override
public boolean onOptionsItemSelected(MenuItem item) {
 //先判断点击的是哪个id
 switch (item.getItemId()) {
  case R.id.font_10:
   mEdt.setTextSize(10 * 2);
   break;
  case R.id.font_12:
   mEdt.setTextSize(12 * 2);
   break;
  case R.id.font_14:
   mEdt.setTextSize(14 * 2);
   break;
  case R.id.font_16:
   mEdt.setTextSize(16 * 2);
   break;
  case R.id.font_18:
   mEdt.setTextSize(18 * 2);
   break;
  case R.id.blue:
   mEdt.setTextColor(Color.BLUE);
   break;
  case R.id.red:
   mEdt.setTextColor(Color.RED);
   break;
  case R.id.green:
   mEdt.setTextColor(Color.GREEN);
   break;
 }
 return super.onOptionsItemSelected(item);
}

运行结果:

简单的菜单布局就这些了,对于菜单还有另一种方法,那就是上下文菜单,有关上下文菜单,下次介绍<

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 属于自己的常见Android选项菜单样式集合

    菜单是用户界面中最常见的元素之一,使用非常频繁,在Android中,菜单被分为如下三种,选项菜单(OptionsMenu).上下文菜单(ContextMenu)和子菜单(SubMenu),今天这讲是OptionsMenu 一.概述 public boolean onCreateOptionsMenu(Menu menu):使用此方法调用OptionsMenu . public boolean onOptionsItemSelected(MenuItem item):选中菜单项后发生的动作. pu

  • Android中选项菜单(OptionMenu)的创建方法

    使用OptionMenu 只要重写两个方法 public boolean onCreateOptionsMenu(Menu menu):菜单的初始化 public boolean onOptionsItemSelected(MenuItem item):菜单响应事件 除此之外,还有三个方法可以重写 public void onOptionsMenuClosed(Menu menu):菜单关闭时调用 public boolean onPrepareOptionsMenu(Menu menu):选项

  • Android选项菜单用法实例分析

    本文实例讲述了Android选项菜单用法.分享给大家供大家参考.具体如下: Android平台下所提供的菜单大体上可分为三类:选项菜单.上下文菜单和子菜单. 当Activity在前台运行时,如果用户按下手机上的Menu键,此时就会在屏幕低端弹出相应的选项菜单.但这个功能需要开发人员编程来实现的,如果在开发应用程序时没有实现该功能,那么程序运行时按下手机的meun键是不会起作用的. 对于携带图标的选项菜单,每次最多只能显示6个,当菜单选项多于6个时,将只显示前5个和一个扩展菜单选项,点击扩展菜单选

  • 基于Android实现点击某个按钮让菜单选项从按钮周围指定位置弹出

    Android Material Design:PopupMenu Android Material Design 引入的PopupMenu类似过去的上下文菜单,但是更灵活. 如图所示: 现在给出实现上图PopupMenu的代码. 本例是一个普通的Button触发弹出PopupMenu. 测试的MainActivity.java : package zhangphil.materialdesign; import android.app.Activity; import android.os.B

  • Android开发实现SubMenu选项菜单和子菜单示例

    本文实例讲述了Android开发实现SubMenu选项菜单和子菜单.分享给大家供大家参考,具体如下: 简介: SubMenu:代表一个子菜单,包含1~N个MenuItem 实现效果: 具体实现方法: 主活动 MainActivity: public class MainActivity extends AppCompatActivity { //定义 "字体大小" 菜单项的标识 final int FONT_10 = 0x111; final int FONT_12 = 0x112;

  • android在连拍菜单中增加连拍张数选项功能实现代码

    修改\packages\apps\Camera\res\values\arrays.xml中的以下代码: 复制代码 代码如下: <string-array name="pref_camera_continuous_number_entries"> <item>@string/pref_camera_continuous_number_normal</item> <item>@string/pref_camera_continuous_nu

  • Android实现选项菜单子菜单

    Android之选项菜单和子菜单学习笔记,供大家参考,具体内容如下 菜单简介: 菜单在桌面应用中使用十分广泛,几乎所有的桌面应用都有菜单.但是随着手机的发展,对于手机桌面菜单的使用减少了很多,一般来说我们把菜单都放到应用中是实现,桌面应用的菜单与手机应用的菜单的不同之处就是,桌面菜单一般可见,而手机不可见,通常需要用户按下手机上的MENU键时,才会弹出菜单的相关应用,这里简单的来说下菜的简单使用情况,通过一个小案例来讲解. 一般菜单的创建有两种方式,一种是在Java代码中创建,一种是在XML中创

  • 解决element-ui中下拉菜单子选项click事件不触发的问题

    将@click改为@click.native='logoutHandle';即可监听选项的点击事件. <el-dropdown class="pull-right" > <span class="el-dropdown-link"> <img src="./img/header.jpg" alt="" class="pull-right"> </span> &

  • Android自定义VIew实现卫星菜单效果浅析

     一 概述: 最近一直致力于Android自定义VIew的学习,主要在看<android群英传>,还有CSDN博客鸿洋大神和wing大神的一些文章,写的很详细,自己心血来潮,学着写了个实现了类似卫星效果的一个自定义的View,分享到博客上,望各位指点一二.写的比较粗糙,见谅.(因为是在Linux系统下写的,效果图我直接用手机拍的,难看,大家讲究下就看个效果,勿喷). 先来看个效果图,有点不忍直视: 自定义VIew准备: (1)创建继承自View的类; (2)重写构造函数; (3)定义属性. (

  • Android如何给Textview添加菜单项详解(Java)

    目录 背景描述: 解决办法 具体步骤: 1.创建菜单文件 2.给activity添加菜单,重写菜单监听事件 3. 给控件添加菜单响应属性 总结 背景描述: 界面上有一个Textview和一个Button,当我们点击Textview时会弹出一个菜单,然后我们选择一个选项,最后点击按钮的时候,就会根据选择的菜单项执行相应的函数. 解决办法 总共分三个步骤: 1.首先在res文件夹下创建menu文件夹,然后创建菜单文件main.xml 2.在Activity中添加菜单,具体怎么添加,先定义菜单按钮 P

  • Android仿美团下拉菜单(商品选购)实例代码

    美团电商应用平台大家使用非常频繁,下面小编通过本文给大家介绍电商应用平台中常用的选择类别下拉列表的实现.先给大家展示下效果图: 一.下拉列表的实现 其实实现方法有很多,这时实现的也没有什么技术含量,只是总结下自己在项目中的做法,也提供一个思路. 首先是列表的数据,一般数据都是从后台读过来,这里因为没有后台,所以写死在客户端: private void initMenuData() { menuData = new ArrayList<map<string, string=""

  • js实现多选项切换导航菜单的方法

    本文实例讲述了js实现多选项切换导航菜单的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>多选项切换导航菜单</title> </head> <style type="text/c

  • Android仿QQ空间底部菜单示例代码

    之前曾经在网上看到Android仿QQ空间底部菜单的Demo,发现这个Demo有很多Bug,布局用了很多神秘数字.于是研究了一下QQ空间底部菜单的实现,自己写了一个,供大家参考.效果如下图所示:   1.实现原理很简单,底部菜单是一个水平分布的LinearLayout,里面又是五个LinearLayout,它们的layout_weight都为1,意味着底部菜单的子控件将屏幕宽度平均分为5部分.五个LinearLayout除了中间那个,其余都在里面放置ImageView和TextView(中间先空

  • Android开源组件SlidingMenu侧滑菜单使用介绍

    现在很多android应用都有侧滑菜单,效果很不错. GitHub上有SlidingMenu的开源库,使用起来很方便. SlidingMenu GitHub地址:https://github.com/jfeinstein10/SlidingMenu.GitHub上说,Sliding结合ActionBarSherlock使用功能可以更丰富,ActionBarSherlock GitHub地址:https://github.com/JakeWharton/ActionBarSherlock 附csd

  • Android提高之多级树形菜单的实现方法

    一般来说在Android里要实现树形菜单,都是用ExpandableList(也有高手自己继承ListView或者LinearLayout来做),但是ExpandableList一般只能实现2级树形菜单.本文所述实例也依然使用ExpandableList,但是要实现的是3级树形菜单. 本文程序运行效果图如下图所示: 当用BaseExpandableListAdapter来实现二级树形菜单时,父项(getGroupView())和子项(getChildView())都是使用TextView.当要实

随机推荐