Menu
菜单在手机应用中的使用减少了不少,主要受到手机屏幕大小制约,但是依然有不少手机应用添加菜单。Android应用中的菜单默认是看不见的,只有当用户单击手机的MENU健时,系统才会显示该应用关联的菜单,这种菜单叫做选项菜单(OptionMenu)。
Android同样支持上下文菜单(ContextMenu),当用户一直按住某个组件时,该组件所关联的上下文菜单就显示出来。
三种菜单类型:
1)OptionMenu 通过点击Menu按钮触发
重写onCreateOptionsMenu(),在方法里调用Menu对象的方法添加菜单项或者子菜单
返回true代表显示菜单出来
重写onOptionsItemSelected()为MenuItem单击作出响应事件
返回true表示处理完菜单项的事件,不需要将该事件继续传播下去了
2)ContextMenu 通过LongClick控件触发
重写onCreateContextMenu()创建MenuItem
重写onContextItemSelected为MenuItem作出响应
需要给控件注册上下文菜单:
3)PopupMenu 弹出式菜单
创建PopMenu对象,指定绑定的控件
调用getMenuInflater().inflate(R.menu.xml_menu1,
pop.getMenu())方法加载MenuItem资源
调用show()方法显示PopMenu
调用setOnMenuItemClickListener()为其设置监听
菜单的结构:
Menu 是一个父接口,代表一个菜单,android用它来管理各种菜单项。注意我们一般不自己创建menu,因为每个Activity默认都自带了一个,我们要做的是为它加菜单项和响应菜单项的点击事件。
—SubMenu 子菜单,可以包含1到N个MenuItem
—ContextMenu 上下文菜单,可以包含1到N个MenuItem
—MenuItem 菜单项
创建菜单的两种方式:
1)代码添加
add(groupId,Id,Order,Title)添加普通菜单项
addSubMenu(groupId,Id,Order,Title)添加内容为子菜单的菜单项
groupId 为菜单项设置组编号,一般传0
Id 为菜单项设置自身编号,同组之内不能重复
Order 定菜单项的排列顺序,一般传0
Title 指定文字
注意:通过add(Title)或addSubMenu(Title)
添加的菜单项为默认0组的菜单项
MenuItem还提供如下方法来设置快捷键:
setIcon(int):设置菜单项的图标
2)通过Menu菜单文件添加(推荐使用)
<item>
<menu>
...<!--子菜单-->
</menu>
</item>
<group>
<!--子元素--->
<item/>
<item/>
<item/>
</group>
中指定的常用属性:
checkableBehavior:指定菜单的选择行为,多选,单选,不可选
menuCategory:对菜单进行分类,指定菜单的优先级
visible:该组菜单是否可见
enable:该组菜单是否可用
中指定的常用属性:
android:id为菜单项指定一个唯一标识
android:title菜单项的标题
android:icon菜单项的图标
android:checkable 菜单项是否可选
android:checked 菜单项是否已被选
android:visible 菜单项是否可见
android:enable 菜单项是否可用
android:numericShortcut 菜单项数字快捷健
android:alphabeticShortcut菜单项字符快捷健
实例代码:
MainActivity:
package com.briup.menu;
import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.PopupMenu;
import android.widget.PopupMenu.OnMenuItemClickListener;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity {
private TextView tv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv=(TextView)findViewById(R.id.tv);
//给控件注册上下文菜单
tv.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
PopupMenu popupMenu=new PopupMenu(MainActivity.this, v);
getMenuInflater().inflate(R.menu.main, popupMenu.getMenu());
popupMenu.show();
popupMenu.setOnMenuItemClickListener(new OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
// TODO Auto-generated method stub
switch (item.getItemId()) {
case R.id.item1:
Toast.makeText(MainActivity.this, "扫一扫", Toast.LENGTH_SHORT).show();
break;
case R.id.item2:
Toast.makeText(MainActivity.this, "添加朋友", Toast.LENGTH_SHORT).show();
break;
}
return false;
}
});
}
});
registerForContextMenu(tv);
}
/**
* 用来去制作选项菜单 三个小点:overflow 两种方式: 1.java代码 2.菜单的布局文件
*/
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
// 添加一个普通菜单项
// menu.add(0, 1, 1, "扫一扫");
// menu.add(0, 2, 2, "添加朋友");
// //添加含有子菜单的菜单项
// SubMenu subMenu = menu.addSubMenu(0, 3, 3, "字体颜色");
// subMenu.add(0, 4, 3, "红色");
// subMenu.add(0, 5, 2, "绿色");
// subMenu.add(0, 6, 1, "蓝色");
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// TODO Auto-generated method stub
switch (item.getItemId()) {
case R.id.item1:
Toast.makeText(this, "扫一扫", Toast.LENGTH_SHORT).show();
break;
case R.id.item2:
Toast.makeText(this, "添加朋友", Toast.LENGTH_SHORT).show();
break;
}
return super.onOptionsItemSelected(item);
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
// TODO Auto-generated method stub
getMenuInflater().inflate(R.menu.main, menu);
super.onCreateContextMenu(menu, v, menuInfo);
}
@Override
public boolean onContextItemSelected(MenuItem item) {
// TODO Auto-generated method stub
return super.onContextItemSelected(item);
}
}