安卓导航视图徽章上的菜单图标

问题描述:

我使用幻灯片抽屉的导航视图,并使用app:menu属性设置选项。我想在菜单图标上显示通知计数。 我在菜单xml中指定了android:actionLayout,但它显示标题右侧的徽章,但我希望它位于图标的右上角。
我的代码是这样的:安卓导航视图徽章上的菜单图标

<android.support.design.widget.NavigationView 
     android:id="@+id/navigation" 
     android:layout_width="wrap_content" 
     android:layout_height="match_parent" 
     android:layout_gravity="end" 
     android:background="?attr/colorPrimary" 
     app:headerLayout="@layout/navigation_header" 
     app:itemIconTint="@android:color/white" 
     app:itemTextColor="@android:color/white" 
     app:menu="@menu/menu_main" /> 

main_menu.xml

<menu xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto"> 
<group 
    android:checkableBehavior="single"> 
    . 
    . 
    . 
    . 
    <item 
     android:id="@+id/drawer_notification" 
     android:icon="@drawable/menu_notfication" 
     app:actionViewClass="android.widget.TextView" 
     android:actionLayout="@layout/menu_counter" 
     android:title="Notification"/> 
    <item 
     android:id="@+id/drawer_settings" 
     android:icon="@drawable/menu_setting" 
     android:title="Settings"/> 
    <item 
     android:id="@+id/drawer_faq_help" 
     android:icon="@drawable/menu_faq" 
     android:title="FAQ and Help"/> 

    . 
    . 
    .  
</group> 

menu_counter.xml

<?xml version="1.0" encoding="utf-8"?> 
<TextView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_gravity="center_vertical" 
    android:background="@drawable/circle_bagde" 
    android:gravity="center_vertical" 
    android:padding="5dp" 
    android:text="12" 
    android:textColor="@android:color/white" 
    android:textSize="16sp" /> 

我希望它是这样的:
enter image description here

您可以使用SublimeNavigationView来执行此操作。

如果您不想使用第三方抽屉,那么您可以使用RecyclerViewListView而不是NavigationView创建导航抽屉。您可以轻松地自定义RecyclerViewListView

您也可以自定义NavigationView。

只需使用下面的代码即可。

<android.support.design.widget.NavigationView 
    android:layout_width="300dp" 
    android:layout_gravity="start" 
    android:id="@+id/navigationView" 

    android:layout_height="match_parent"> 

    <include layout="@layout/drawer_layout"/> 
</android.support.design.widget.NavigationView> 

现在包括标签,添加一个布局与回收,并在recyclerView的onCreateView给回收商想要的布局和设置要在onBind方法来设置像你一样正常的任何值。

只要记得在导航视图中调用findViewById回收器就像:navigationView.findViewById(R.id.recyclerVIew)