13

使用以下代码

<item 
    android:id="@+id/text"
    android:title="@string/mainMenu"
    android:enabled="false"
    android:layout_gravity="center">
</item>

我的风格定义为

<style name="MenuTextStyle" parent="@android:style/TextAppearance.Medium">
    <item name="android:textColor">6F6B6B</item>
    <item name="android:gravity">center_horizontal</item>
    <item name="android:textStyle">bold</item>
    <item name="android:textSize">14sp</item>

但是菜单文本仍然不在中间。如何让它居中?

4

3 回答 3

15

您可以在活动中使用动态居中对齐菜单项SpannableString

int positionOfMenuItem = 0; //or any other postion
MenuItem item = menu.getItem(positionOfMenuItem);
SpannableString s = new SpannableString(settingsItemTitle);

s.setSpan(new AlignmentSpan.Standard(Alignment.ALIGN_CENTER), 0, s.length(), 0);

item.setTitle(s);
于 2013-10-21T08:26:24.900 回答
1

我使用了@Mahm00d 的方法,效果很好,但我找到了另一种解决问题的方法。它是\t在字符串之前添加的。如果空间不够,我可以添加更多。

因为中文单词是一一对应的,所以项目的长度是一样的。

于 2017-03-13T15:50:12.517 回答
0

实现此目的的另一种方法是通过设置主题

 <android.support.design.widget.NavigationView
    android:id="@+id/nav_view"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:fitsSystemWindows="true"
    android:theme="@style/ThemeToolbar.NavigationViewPadding"
    app:itemTextColor="@color/inverse_color"
    app:itemIconTint="@color/inverse_color"
    app:itemBackground="@drawable/selector_navigation"
    app:headerLayout="@layout/activity_home_nav_header"
    app:menu="@menu/activity_home_drawer" />

在你的风格

    <style name="ThemeToolbar.NavigationViewPadding">
    <item name="listPreferredItemPaddingLeft">50dp</item>
    </style>

它看起来如何

于 2016-12-15T18:27:21.323 回答