如何给导航抽屉的菜单项上色?
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>
要将所有图标刷成特定颜色,您需要将app:itemIconTint
添加到您的NavigationView
:
<android.support.design.widget.NavigationView
........
app:itemIconTint="<your color>"/>
刷你的图标只有 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" />
刷不同颜色的所有图标,就像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 使用 VectorDrawable
s 而不是旧的 BitmapDrawables
,所以这段代码在那里不起作用。
希望对您有所帮助。
我正在创建导航抽屉,我看到 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>
要将所有图标刷成特定颜色,您需要将
app:itemIconTint
添加到您的NavigationView
:<android.support.design.widget.NavigationView ........ app:itemIconTint="<your color>"/>
刷你的图标只有 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" />
刷不同颜色的所有图标,就像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 使用VectorDrawable
s 而不是旧的BitmapDrawables
,所以这段代码在那里不起作用。
希望对您有所帮助。