700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 自定义menu菜单布局

自定义menu菜单布局

时间:2019-04-03 22:19:19

相关推荐

自定义menu菜单布局

一:先写一个自定义的菜单布局

这个布局可以根据业务需要任意写

<?xml version="1.0" encoding="utf-8"?><TextView xmlns:android="/apk/res/android"android:layout_width="wrap_content"android:layout_height="wrap_content"android:paddingLeft="10dip"android:paddingRight="10dip"android:gravity="center"android:text="收藏"android:drawableLeft="@mipmap/me_collect"android:drawablePadding="3dp"android:textColor="@color/title_color"android:clickable="true" />

二:在menu的item中引用该布局

这了用到了app:actionLayout来指定自定义菜单布局,需要注意的是必须是app:actionLayout,而不应该是android:actionLayout,否则onCreateOptionsMenu方法中的getActionView()方法会返回null。

<?xml version="1.0" encoding="utf-8"?><menu xmlns:android="/apk/res/android"xmlns:app="/apk/res-auto"><!--1:actionLayout用于指定你自定义的菜单布局;2:必须是app:actionLayout,而不应该是android:actionLayout否则onCreateOptionsMenu方法中的getActionView()方法会返回null--><item android:id="@+id/flavor"android:title=""app:showAsAction="always"app:actionLayout="@layout/head_flavor_menu" /></menu>

三:onCreateOptionsMenu(Menu menu)中引用该布局

这一步的目的是将你自定义的菜单当成普通菜单处理,通过给自定义的菜单布局设置单击事件,让其在单击时执行onOptionsItemSelected(MenuItem item),从而让其像普通的Menu item一样在onOptionsItemSelected中处理点击事件就可以了。

@Overridepublic boolean onCreateOptionsMenu(Menu menu) {getMenuInflater().inflate(R.menu.head_flavors, menu);final MenuItem item = menu.findItem(R.id.flavor);// getActionView()返回你自定义的菜单布局,设置单击事件的目的是,让其单击时执行onOptionsItemSelected,从而只需统一在onOptionsItemSelected处理即可item.getActionView().setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {onOptionsItemSelected(item);}});return super.onCreateOptionsMenu(menu);}

四:没有第四步了!

由第三步可知,onOptionsItemSelected(MenuItem item) 方法无需做任何改变。

五:最后看看效果

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。