如何更改导航抽屉字体?

时间:2016-01-05 12:22:08

标签: android fonts navigation-drawer right-to-left

我想在android中使用我自己的字体导航抽屉。我根据这个答案使用了android studio附带的库:https://stackoverflow.com/a/23632492/4393226。 但我不知道如何更改字体并使其成为RTL。 我搜索了很多,我发现了如何制作抽屉RTL。我使用这段代码:

getWindow().getDecorView().setLayoutDirection(View.LAYOUT_DIRECTION_RTL);

Android - Is Navigation Drawer from right hand side possible?

但是如您所知,这仅适用于API 17及更高版本。 请帮忙!如何更改菜单字体?如何以正确的方式进行布局RTL?!

被修改: 我的字体" TTF"文件是资产/字体,我知道如何使用java为textview设置它,但我不知道如何将其设置为导航抽屉菜单。

6 个答案:

答案 0 :(得分:35)

我找到了答案: 首先在项目中创建此类:

import android.graphics.Paint;
import android.graphics.Typeface;
import android.text.TextPaint;
import android.text.style.TypefaceSpan;

public class CustomTypefaceSpan extends TypefaceSpan {

    private final Typeface newType;

    public CustomTypefaceSpan(String family, Typeface type) {
        super(family);
        newType = type;
    }

    @Override
    public void updateDrawState(TextPaint ds) {
        applyCustomTypeFace(ds, newType);
    }

    @Override
    public void updateMeasureState(TextPaint paint) {
        applyCustomTypeFace(paint, newType);
    }

    private static void applyCustomTypeFace(Paint paint, Typeface tf) {
        int oldStyle;
        Typeface old = paint.getTypeface();
        if (old == null) {
            oldStyle = 0;
        } else {
            oldStyle = old.getStyle();
        }

        int fake = oldStyle & ~tf.getStyle();
        if ((fake & Typeface.BOLD) != 0) {
            paint.setFakeBoldText(true);
        }

        if ((fake & Typeface.ITALIC) != 0) {
            paint.setTextSkewX(-0.25f);
        }

        paint.setTypeface(tf);
    }
}

然后将此方法添加到您想要更改导航抽屉菜单字体的活动中:

private void applyFontToMenuItem(MenuItem mi) {
        Typeface font = Typeface.createFromAsset(getAssets(), "ds_digi_b.TTF");
        SpannableString mNewTitle = new SpannableString(mi.getTitle());
        mNewTitle.setSpan(new CustomTypefaceSpan("" , font), 0 , mNewTitle.length(),  Spannable.SPAN_INCLUSIVE_INCLUSIVE);
        mi.setTitle(mNewTitle);
}

然后添加调用您刚刚在活动中添加的方法:

navView = (NavigationView) findViewById(R.id.navView);
Menu m = navView.getMenu();
for (int i=0;i<m.size();i++) {
    MenuItem mi = m.getItem(i);

    //for aapplying a font to subMenu ...
    SubMenu subMenu = mi.getSubMenu();
    if (subMenu!=null && subMenu.size() >0 ) {
        for (int j=0; j <subMenu.size();j++) {
            MenuItem subMenuItem = subMenu.getItem(j);
            applyFontToMenuItem(subMenuItem);
        }
    }

    //the method we have create in activity
    applyFontToMenuItem(mi);
}

答案 1 :(得分:9)

添加到rischan的答案。

我直接编辑'mi',因为那些是我的抽屉菜单标题。然后我更改了s.setSpan 1st参数以使用自定义类CustomTypefaceSpan。

private static final ArrayList<MovieItem> NUM_MOVIES = ;

CustomTypefaceSpan类:

    // Navigation View
    NavigationView navigationView = (NavigationView) 
    findViewById(R.id.nav_view);
    navigationView.setNavigationItemSelectedListener(this);

    Menu m = navigationView .getMenu();

    Typeface tf1 = Typeface.createFromAsset(getAssets(), "font/Gotham Narrow Extra Light.otf");

    for (int i=0;i<m.size();i++) {

        MenuItem mi = m.getItem(i);

        SpannableString s = new SpannableString(mi.getTitle());
        s.setSpan(new CustomTypefaceSpan("", tf1), 0, s.length(),
                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
        mi.setTitle(s);

    }

无法相信更改菜单字体的复杂程度。

答案 2 :(得分:8)

第1步:在style.xml中进行如下样式

<style name="NavigationView" >
<item name="fontFamily">@font/helvetica_neue_light</item>
</style>

步骤2: 在您的样式中添加样式作为主题 android.support.design.widget.NavigationView

android:theme =“ @ style / NavigationView”

答案 3 :(得分:8)

您可以以更简单的方式进行操作。

首先进入style.xml并在那里创建新样式。

 <style name="RobotoTextViewStyle" parent="android:Widget.TextView">
      <item name="android:fontFamily">@font/sans-serif-smallcaps</item>
 </style>

第二个是转到您的导航xml代码,并在其中放置项目文本外观

app:itemTextAppearance="@style/RobotoTextViewStyle"

现在您的最终导航代码应该是这个。

<android.support.design.widget.NavigationView
        android:id="@+id/nav_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        app:itemTextAppearance="@style/RobotoTextViewStyle"
        android:fitsSystemWindows="true"
        app:headerLayout="@layout/nav_header_home"
        app:menu="@menu/activity_home_drawer" />

答案 4 :(得分:4)

谢谢!我已经成功更改了基于@Amir H post的导航抽屉上的字体,但是使用了配置(只需将这几行添加到您的活动中)

NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
        navigationView.setNavigationItemSelectedListener(this);
        Menu m = navigationView .getMenu();

        for (int i=0;i<m.size();i++) {
            MenuItem mi = m.getItem(i);

            //for applying a font to subMenu ...
            SubMenu subMenu = mi.getSubMenu();
            if (subMenu!=null && subMenu.size() >0 ) {
                for (int j=0; j <subMenu.size();j++) {
                    MenuItem subMenuItem = subMenu.getItem(j);
                    SpannableString s = new SpannableString(subMenuItem.getTitle());
                    s.setSpan(new TypefaceSpan("fonts/yourfontname.ttf"), 0, s.length(),
                            Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
                    subMenuItem.setTitle(s);
                }
            }

        }

也许它会帮助某人:)

答案 5 :(得分:2)

仅适用于字体

  1. First Of All在位于colors.xml的{​​{1}}文件中添加您的字体颜色(如果您想更改)

    res->values->colors.xml
  2. 然后编辑位于相同值目录的<color name="black">#000000</color> // it's for black don't go for white color 文件(有两个文件编辑具有样式style.xml主题的文件或在该两个文件中找到行

    < / LI>
  3. 这里我们要设置font属性。因此,您必须在封闭资源标记中创建新的样式标记。在我的情况下,我创建

    name="your_theme"

    请注意,此标记的名称为<style name="MyText" parent="@android:style/TextAppearance.Medium"> <item name="android:textSize">20sp</item> //size of font <item name="android:textColor">@color/black</item> //color of font <item name="android:typeface">sans</item> // type how it appear </style> 。现在我们必须在上面的第一个样式块中使用此名称,其名称是您的应用主题。

  4. 在上面的appication主题样式标记中提到了这个新样式。就我而言,它就像

    MyText