App compat主题的弹出菜单分隔符

时间:2016-04-05 12:31:09

标签: android popupmenu

我使用了app compat主题样式。

  <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- Customize your theme here. -->
        <item name="android:popupMenuStyle">@style/PopupMenu</item>
        <item name="android:itemTextAppearance">@style/myCustomMenuTextApearance</item>
        <item name="android:listPopupWindowStyle">@style/PopupMenuStyle</item>

    </style>
    <style name="PopupMenuStyle" parent="Widget.AppCompat.ListPopupWindow">
        <item name="android:divider">@drawable/devider</item>
        <item name="android:dividerHeight">2dp</item>
    </style>

    <style name="PopupMenu" parent="@android:style/Widget.PopupMenu">
        <item name="android:popupBackground">@color/search_panel_color</item>
        <item name="android:textColor">@color/activity_button_text_color</item>
        <item name="android:shadowColor">@color/activity_theam_color</item>


    </style>

    <style name="myCustomMenuTextApearance" parent="@android:style/TextAppearance.Widget.TextView.PopupMenu">
        <item name="android:textColor">@color/activity_theam_color</item>
    </style>

我想在菜单项中添加分隔符。 我已经尝试了很多东西,但分频器没有应用...... 有没有办法显示分隔符?

7 个答案:

答案 0 :(得分:3)

我也有同样的问题。解决方案是这样的:

<style name="PopupMenuListView" parent="@style/Widget.AppCompat.ListView.DropDown">
    <item name="android:divider">#000000</item>
    <item name="android:dividerHeight">1dp</item>
</style>
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">   
  <item name="android:dropDownListViewStyle">@style/PopupMenuListView</item>
</style>

您还可以参考以下链接: How to add dividers between specific menu items?

答案 1 :(得分:2)

根据您的主题风格,我猜您使用了Toolbar。您的菜单弹出窗口是否显示在Toolbar?如果是这样,您可以自定义为以下步骤。

定义主题

<style name="AppToolbarPopupTheme" parent="Widget.AppCompat.PopupMenu.Overflow">
    <item name="android:dropDownListViewStyle">@style/AppDropDownListViewStyle</item>
</style>

<style name="AppDropDownListViewStyle" parent="Widget.AppCompat.ListView.DropDown">
    <item name="android:divider">@drawable/line_divider</item>
    <item name="android:dividerHeight">1dp</item>
</style>

然后将主题应用于Toolbar

<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:popupTheme="@style/AppToolbarPopupTheme">

</android.support.v7.widget.Toolbar>

答案 2 :(得分:2)

如果你还没有找到这个问题的答案,那么这就是我使用风格的方式:

    <style name="PopupMenu">
    <item name="android:itemBackground">@color/background_medium_gray</item>
    <item name="android:background">@android:color/transparent</item>
    <item name="android:textColor">@android:color/black</item>
    <item name="android:colorBackground">@color/BackgroundGray</item>
    <item name="android:dividerHeight">1dp</item>
</style>

    Context context = new ContextThemeWrapper(getActivity(), R.style.PopupMenu);
    final PopupMenu popupMenu = new PopupMenu(context, view);

    final MenuInflater menuInflater = popupMenu.getMenuInflater();

答案 3 :(得分:1)

我建议您添加虚拟组,尝试这种方式

<group>
    <!--add it like as a separator-->
    <item
        android:title=""
        android:showAsAction="always"
        android:enabled="false" />
</group>

答案 4 :(得分:1)

我有一个解决方案。您可以根据您的选择通过编程设计弹出窗口。使用下面的代码显示弹出菜单。

import {Injectable} from 'angular2/core';
import * as mqtt from 'mqtt';
@Injectable() 
export class MqttService {
  constructor() {
     //mqtt.connect('ws://10.0.1.100:3333')
     // ...
  }
}

这里listpopupadapter是用于设计列表的类,如下所示。

private ListPopupWindow listPopupWindow;
listPopupWindow = new ListPopupWindow(getApplicationContext());
listPopupWindow.setWidth(400);
listPopupWindow.setDropDownGravity(Gravity.CENTER);
listPopupWindow.setAdapter(new listpopupadapter(a, type));
listPopupWindow.setAnchorView(v);
listPopupWindow.show();

答案 5 :(得分:1)

使用Material主题删除分隔符。可能这是解决此问题的简单方法。

你可以尝试这个或任何全息主题(即@android:style / Widget.ListPopupWindow)来获得弹出窗口中的分隔效果

<!-- Change Overflow Menu ListView Divider Property -->
<style name="PopupMenuListView" parent="android:Widget.ListPopupWindow">
    <item name="android:divider">#FF0000</item>
    <item name="android:dividerHeight">2dp</item>
</style>

答案 6 :(得分:0)

我已经制作了一个需要弹出窗口的驱动程序应用程序,当时我使用了这个。所以请试试这个。也许它会有所帮助。

<activity
    android:name="driver_activity_name
    android:theme="@android:style/Theme.Translucent.NoTitleBar" />