如何给导航抽屉的菜单项上色?

How to give color to menu items for Navigation drawer?

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

这是我的代码

<?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>
  1. 要将所有图标刷成特定颜色,您需要将app:itemIconTint添加到您的NavigationView:

    <android.support.design.widget.NavigationView
         ........
         app:itemIconTint="<your color>"/>
    

  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>
    

    并将其作为 app:itemIconTint 应用到您的 NavigationView:

    <android.support.design.widget.NavigationView
         ........
         app:itemIconTint="@drawable/tint_color_selector"/>
    

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

     <item
        android:id="@+id/nav_slideshow"
        android:checked="true"
        android:icon="@drawable/ic_menu_slideshow"
        android:title="Slideshow" />
    

  3. 不同颜色的所有图标,就像Google在Google播放:

    禁用图标着色:

      navigationView.setItemIconTintList(null);
    

    将您想要的图标添加到 res/drawable 并在菜单的 xml 中将它们指定为 android:icon。 (我可以为 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);
    

    注意! 在模板项目中的 res/drawables-v21 中,Google 使用 VectorDrawables 而不是旧的 BitmapDrawables,所以这段代码在那里不起作用。

希望对您有所帮助。