Activity和Fragment都有用于管理菜单的回调函数
创建
public void onCreateOptionsMenu(Menu menu,MenuInflater inflater)
响应菜单事件
public boolean onOptionsItemSelected(MenuItem item)
需要选项菜单时Android会调用Activity的onCreateOptionsMenu方法,Fragment的该方法是由FragmentManager调用的,因此Activity接收到回调请求时应通知FragmentManager
那就首先要让FragmentManager知道这个fragment是需要接收选项菜单的回调的
在fragment的onCreate方法中调用以下方法
public void setHasOptionsMenu(boolean hasMenu)
创建菜单资源
res/menu.fragment_crime_list
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/menu_item_new_crime"
android:icon="@drawable/ic_menu_add"
android:title="@string/new_crime"
app:showAsAction="ifRoom|withText"/>
<!--AppCompat库需要使用app命名空间-->
<!--icon属性中引用了系统图标-->
<item
android:id="@+id/menu_item_show_subtitle"
android:title="@string/show_subtitle"
app:showAsAction="ifRoom"/>
</menu>
showAsAction属性用于指定菜单项是显示在工具栏还是在overflow menu里
该属性还有always与never属性
用app命名空间是因为AppCompat库不希望使用原生showAsAction属性
右键drawable->new->Image Assets 在弹出的Asset Studio窗口中选择想要使用的系统图标
创建菜单
//由FragmentManager来调用
@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater){
super.onCreateOptionsMenu(menu,inflater);
inflater.inflate(R.menu.fragment_crime_list,menu);
//将布局文件中的菜单项目填充到布局实例中
//更新菜单项
MenuItem subtitleItem=menu.findItem(R.id.menu_item_show_subtitle);
if(mSubtitleVisible) {
subtitleItem.setTitle(R.string.hide_subtitle);
}else{
subtitleItem.setTitle(R.string.show_subtitle);
}
}
更新菜单项是为了在显示crime数目的子标题隐藏时,菜单项显示show subtitle否则显示hide subtitle
如果是在用户点击菜单项时,在处理菜单项点击事件中修改的话,但如果设备旋转重建菜单项时子标题的变化会失效,所以最好在create菜单项时更改,然后在处理点击事件时更新菜单项
getActivity().invalidateOptionsMenu();
处理菜单项的点击事件
@Override
public boolean onOptionsItemSelected(MenuItem item){
switch (item.getItemId()){
case R.id.menu_item_new_crime:
Crime crime=new Crime();
CrimeLab.get(getActivity()).addCrime(crime);
Intent intent=CrimePagerActivity.newIntent(getActivity(),crime.getId());
startActivity(intent);
return true;
case R.id.menu_item_show_subtitle:
mSubtitleVisible=!mSubtitleVisible;
//重建菜单项
getActivity().invalidateOptionsMenu();
updateSubtitle();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
}