如何为导航抽屉的菜单项添加颜色?

arc*_*tjn 7 android menuitem

我正在创建导航抽屉,我看到playtore有彩色菜单图标,我想知道我该怎么做.我尝试在菜单图标上使用colorFilter应用颜色,但app force关闭

我的应用

我想要的是什么

这是我的代码

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group
    android:id="@+id/grp1"
    android:checkableBehavior="single">
    <item
        android:id="@+id/navigation_songs"
        android:checked="true"
        android:icon="@drawable/ic_audiotrack_white_24dp"
        android:title="@string/songs" />
    <item
        android:id="@+id/navigation_albums"
        android:icon="@drawable/ic_album_white_24dp"
        android:title="@string/albums" />
    <item
        android:id="@+id/navigation_artist"
        android:icon="@drawable/ic_person_white_24dp"
        android:title="@string/artists" />
    <item
        android:id="@+id/navigation_playlist"
        android:icon="@drawable/ic_playlist_play_white_24dp"
        android:title="@string/playlist" />
</group>
<group
    android:id="@+id/grp2"
    android:checkableBehavior="none">
    <item
        android:id="@+id/navigation_about"
        android:icon="@drawable/ic_info_white_24dp"
        android:title="@string/about" />
    <item
        android:id="@+id/navigation_settings"
        android:icon="@drawable/ic_settings_white_24dp"
        android:title="@string/settings" />
</group>
</menu>
Run Code Online (Sandbox Code Playgroud)

Kon*_*nov 15

  1. 要将所有图标刷成特定颜色,您需要添加 app:itemIconTintNavigationView:

    <android.support.design.widget.NavigationView
         ........
         app:itemIconTint="<your color>"/>
    
    Run Code Online (Sandbox Code Playgroud)

    在此输入图像描述

  2. 仅用2种颜色刷你的图标:

    创建一个选择器:

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:color="#0000FF" android:state_checked= "true" />
        <item android:color="#FF0000" />
    </selector>
    
    Run Code Online (Sandbox Code Playgroud)

    并将其应用于app:itemIconTint您的NavigationView:

    <android.support.design.widget.NavigationView
         ........
         app:itemIconTint="@drawable/tint_color_selector"/>
    
    Run Code Online (Sandbox Code Playgroud)

    最后一步 - 要添加android:checked="true"MenuItems您的抽屉菜单xml中,您想要刷不同:

     <item
        android:id="@+id/nav_slideshow"
        android:checked="true"
        android:icon="@drawable/ic_menu_slideshow"
        android:title="Slideshow" />
    
    Run Code Online (Sandbox Code Playgroud)

    在此输入图像描述

  3. 要刷出不同颜色的所有图标,例如Google在Google Play中的图标:

    禁用您的图标着色:

      navigationView.setItemIconTintList(null);
    
    Run Code Online (Sandbox Code Playgroud)

    添加您想要的图标res/drawableandroid:icon在菜单的xml中指定它们.(我可以为Android图标推荐一个很好的服务icons8.com/web-app/new-icons/android)

    在此输入图像描述

    您可以绘制现有的彩色图标,而不是上传新的彩色图标,但它非常hacky:

        Drawable oldIcon = navigationView
                .getMenu()
                .findItem(R.id.nav_gallery)
                .getIcon();
    
        if (!(oldIcon instanceof BitmapDrawable)) {
            return;
        }
    
        Bitmap immutable = ((BitmapDrawable)oldIcon).getBitmap();
        Bitmap mutable = immutable.copy(Bitmap.Config.ARGB_8888, true);
        Canvas c = new Canvas(mutable);
        Paint p = new Paint();
        p.setColor(Color.RED);
        p.setColorFilter(new PorterDuffColorFilter(Color.RED, PorterDuff.Mode.MULTIPLY));
        c.drawBitmap(mutable, 0.f, 0.f, p);
        BitmapDrawable newIcon = new BitmapDrawable(getResources(), mutable);
    
        navigationView
                .getMenu()
                .findItem(R.id.nav_gallery)
                .setIcon(newIcon);
    
    Run Code Online (Sandbox Code Playgroud)

    小心!res/drawables-v21模板项目中,Google使用的VectorDrawable是s而不是旧的BitmapDrawables,因此这段代码无法使用.

我希望,这有帮助.