【发布时间】:2019-11-13 19:59:27
【问题描述】:
我目前正在为我的弹出菜单使用这种样式:
<style name="mainActivityTheme" parent="Theme.MaterialComponents.Light.NoActionBar">
<item name="colorPrimary">@color/colorBlack</item>
<item name="colorPrimaryDark">@color/colorBlack</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
它如何导致弹出菜单在顶部和底部有额外的空间:
如何做到没有多余的空间?是否有特定的样式来包装其内容?
编辑:我忘了提到我以编程方式膨胀视图,所以这可能是一个问题
private void inflateMoreMenu(View view){
PopupMenu popupMenu = new PopupMenu(mContext, view);
popupMenu.inflate(R.menu.popup_menu);
popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
switch (item.getItemId()){
case R.id.popup_menu_report:
//Inflate a layout
break;
case R.id.popup_menu_block:
//Inflate a layout
break;
}
return false;
}
});
@SuppressLint("RestrictedApi")
MenuPopupHelper menuHelper = new MenuPopupHelper(mContext, (MenuBuilder) popupMenu.getMenu(), view);
menuHelper.setForceShowIcon(true);
menuHelper.show();
}
popup_menu 的 XML:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/popup_menu_report"
android:title="Report"
android:icon="@drawable/icon_messages_report"/>
<item
android:id="@+id/popup_menu_block"
android:title="Block"
android:icon="@drawable/icon_alertdialog_block"/>
</menu>
【问题讨论】:
标签: android android-styles popupmenu material-components material-components-android