如果actionBar/Toolbar为白色,则菜单项上没有波纹

Ale*_*rek 4 android toolbar menuitem android-layout android-toolbar

我有白色工具栏,菜单项显示为动作,是来自材质图标的黑色矢量资产.菜单项单击没有涟漪效应,因为涟漪效应也是白色.如果工具栏背景更改为其他颜色(例如蓝色),则会出现波纹.如何更改菜单项波纹颜色,以便在白色背景上可见?我试图改变AppTheme中的colorControlHighlight,但它没有改变菜单项的波纹颜色.

在此输入图像描述

样式

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">  
    <item name="colorPrimary">#ffffff</item>     
</style>
Run Code Online (Sandbox Code Playgroud)

布局

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>

    </android.support.design.widget.AppBarLayout>

</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

菜单

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <item
        android:id="@+id/menu_action_read_all"
        android:icon="@drawable/ic_done_all_black_24dp"
        android:title="@string/menu_notifications_read_all"
        app:showAsAction="ifRoom" />

</menu>
Run Code Online (Sandbox Code Playgroud)

活动

@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {      
    super.onCreate(savedInstanceState);    
    setSupportActionBar((Toolbar) findViewById(R.id.toolbar));     
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.menu_notifications, menu);
    return true;
}
Run Code Online (Sandbox Code Playgroud)

azi*_*ian 9

在你的风格:

<style name="MyToolbarTheme" parent="@style/ThemeOverlay.AppCompat.Light">
    <item name="colorControlHighlight">@color/colorAccent</item>
</style>
Run Code Online (Sandbox Code Playgroud)

将此主题应用于工具栏:

<android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:popupTheme="@style/MyToolbarTheme"/>
Run Code Online (Sandbox Code Playgroud)

结果:

在此输入图像描述

编辑

对于操作项:

<style name="MyAppBarLayoutTheme" parent="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
    <item name="colorControlHighlight">@color/colorAccent</item>
</style>

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:theme="@style/MyAppBarLayoutTheme">

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

</android.support.design.widget.AppBarLayout>
Run Code Online (Sandbox Code Playgroud)

结果:

在此输入图像描述