actionLayout在导航抽屉中的定位

我有以下设置:

<android.support.design.widget.NavigationView style="@style/NavigationView" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="start" app:itemTextAppearance="@style/DrawerTextAppearance" app:menu="@menu/drawer"/> 

菜单/ drawer.xml

 <menu> <item android:id="@+id/messages_item" android:icon="@drawable/ic_notifications_neg" app:actionLayout="@layout/counter" android:title="@string/message_center"/> <item android:id="@+id/search_item" android:icon="@drawable/ic_search_neg" android:title="@string/search"/> </menu> 

布局/ counter.xml

 <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="26dp" android:layout_height="26dp" android:text="55" style="@style/Bubble"/> 

样式:

 <style name="Bubble" parent="android:Widget.TextView"> <item name="android:gravity">center</item> <item name="android:layout_gravity">center_vertical</item> <item name="android:textColor">@android:color/white</item> <item name="android:background">@drawable/bubble</item> </style> 

这产生了以下结果:

截图

尽pipe风格的重力设置,气泡仍显示在顶部。

如何将actionLayout放置在菜单项的中间?

Solutions Collecting From Web of "actionLayout在导航抽屉中的定位"

我设法解决了这个问题。

我不得不把TextView放在一个容器中:

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="match_parent" android:gravity="center" android:orientation="horizontal"> <TextView android:id="@+id/counterView" style="@style/Bubble" android:layout_width="26dp" android:layout_height="26dp" android:text="55"/> </LinearLayout> 

现在计数器显示在菜单项的中间!


UPDATE

计数器更改代码:

 TextView view = (TextView) drawer.getMenu().findItem(R.id.counter_item).getActionView().findViewById(R.id.counterView); view.setText("" + count); 

试试下面:

layout / counter.xml中使用

机器人:重力= “右| center_vertical”

 <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="26dp" android:layout_height="26dp" android:text="55" android:gravity="right|center_vertical" style="@style/Bubble"/>