1.使用的Activitity继承AppCompatActivity
2.在menu文件夹下面创建具体的布局,
例如:
<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_crime" android:icon="@drawable/ic_menu_add" android:title="新的数据" app:showAsAction="ifRoom|withText" /> <item android:id="@+id/menu_itme_showorhide" android:title="显示所有内容" app:showAsAction="ifRoom"/> </menu>
效果:
3.如果想用系统的图标,可以右键drawable目录new->Image Asset,选择自己想要的图标来使用。
4.在fragment中,首先重写onCreateOptionsMenu()方法。
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { super.onCreateOptionsMenu(menu, inflater);//只是为了遵循规范,什么都没做 inflater.inflate(R.menu.fragment_crime_list,menu);//传入菜单栏的布局 MenuItem subTitle=menu.findItem(R.id.menu_itme_showorhide); if(SubTitleshow){ subTitle.setTitle("隐藏内容"); } else { subTitle.setTitle("显示内容"); } }
相应的点击事件则是重写onOptionsItemSelected()方法。
public boolean onOptionsItemSelected(MenuItem item) {//用于相应点击菜单栏功能的响应事件 switch (item.getItemId()){ case R.id.menu_item_crime: Crime crime=new Crime(); CrimeLab.get(getActivity()).addCrime(crime); Intent intent=CrimePagerActivity.newIntent(getActivity(),crime.getmID()); startActivity(intent); return true; case R.id.menu_itme_showorhide: SubTitleshow=!SubTitleshow;//这里用于更新菜单的两句 getActivity().invalidateOptionsMenu(); updateCrimeNumber(); return true; default: return super.onOptionsItemSelected(item); } }
,
在onCreateView()方法中,加上
if(savedInstanceState!=null){ SubTitleshow=savedInstanceState.getBoolean(SAVE_SUBTITLE);//旋转问题2 }
然后再重写onSaveInstanceState()方法:
public void onSaveInstanceState(Bundle outState) { super.onSaveInstanceState(outState); outState.putBoolean(SAVE_SUBTITLE,SubTitleshow);//旋转问题3 }