如何更改分隔符颜色选项菜单项?

3

我想改变我的选项菜单的默认分隔线颜色,你能给我一些建议或技术吗?enter image description here

5个回答

2

在我的导航菜单中它可以工作。 下面这行是必须的。

<item name="android:listDivider">@color/white</item>

这是你的样式

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
        <item name="android:listDivider">@color/white</item>
    </style>
//This is ur menu item.
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <group android:checkableBehavior="single">

        <item
            android:id="@+id/nav_profile"
            android:icon="@drawable/m_profile"
            android:title="@string/my_profile" />
        <group android:id="@+id/my_id">
            <item
                android:id="@+id/nav_coming"
                android:icon="@drawable/m_coming"
                android:title="@string/comingsoon" />
        </group>
 </group>
</menu>

0

对于那些还没有找到这个问题答案的人,这是我解决它的方法,希望它也能对你有用:

        <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();

0
将此项添加到应用程序主题中:
<style name="theme" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="android:dropDownListViewStyle">@style/MyDropDownListView</item>
</style>
<style name="MyDropDownListView" parent="@android:style/Widget.ListView.DropDown">
    <item name="android:divider">@color/transparent</item>
</style>

0

您可以通过将主题设置为弹出菜单来实现

在res文件夹中的style.xml文件中使用以下代码:

 <style name="MyThemePopup" parent="@android:style/Theme.Holo.Light.DarkActionBar">
        <item name="android:textColor">@color/white</item>
        <item name="android:dividerHeight">2px</item>
        <item name="android:divider">#F00</item>
        <item name="android:popupMenuStyle">@style/PopupMenu</item>
    </style>

    <style name="PopupMenu" parent="@android:style/Widget.PopupMenu">
        <item name="android:popupBackground">@color/opaque_black_color_dark</item>
    </style>

以上代码是用于创建主题的,其中<item name="android:divider">#F00</item>用于设置分隔线的颜色。

之后,您可以通过清单文件将创建的主题设置为包含弹出菜单的活动。

   <activity
        android:name="com.android.MainActivity"
        android:theme="@style/MyThemePopup" />

希望这段代码能帮助您实现您的需求,愉快编码 :)

同时添加MyThemePopup也不会使任何分隔符出现。 - EvertvdBraak

0

对我来说没有任何作用,可能是因为AppCompat版本的问题?

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <item name="android:actionBarStyle">@style/MyActionBar</item>
    <item name="actionBarStyle">@style/MyActionBar</item>
    <item name="android:dividerHeight">2dp</item>
    <item name="android:divider">@color/ucc_blue</item>
</style>

无论我将其放置在MyActionBar样式或AppTheme样式中,都不起作用。但是设置分隔符高度确实使我的OptionMenu可滚动....

也许它不起作用是因为它们是子菜单项?


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接