Change the font of tab text in android design support TabLayout

前端 未结 18 1489
执念已碎
执念已碎 2020-11-27 13:38

I\'m trying to work on the new TabLayout from the android design library.

I want to change tab text to custom font. And,I tried to sear

相关标签:
18条回答
  • 2020-11-27 14:07

    To use fonts support in XML feature on devices running Android 4.1 (API level 16) and higher, use the Support Library 26+.

    1. Right click res folder
    2. New -> Android resource directory-> select font -> Ok
    3. Put your myfont.ttf file in newly created font folder

    On res/values/styles.xml add:

    <style name="customfontstyle" parent="@android:style/TextAppearance.Small">
        <item name="android:fontFamily">@font/myfont</item>
    </style>
    

    On layout file add app:tabTextAppearance="@style/customfontstyle",

    <android.support.design.widget.TabLayout
        android:id="@+id/tabs"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabGravity="fill"
        app:tabTextAppearance="@style/customfontstyle"
        app:tabMode="fixed" />
    

    Please refer to [fonts in xml].(https://developer.android.com/guide/topics/ui/look-and-feel/fonts-in-xml)

    0 讨论(0)
  • 2020-11-27 14:08

    My Resolve method just like this ,change the Specified tab text ,

     ViewGroup vg = (ViewGroup) tabLayout.getChildAt(0);
     ViewGroup vgTab = (ViewGroup) vg.getChildAt(1);
     View tabViewChild = vgTab.getChildAt(1);
     if (tabViewChild instanceof TextView) {
          ((TextView) tabViewChild).setText(str);
     }
    
    0 讨论(0)
  • 2020-11-27 14:12

    Change

    if (tabViewChild instanceof TextView) {

    for

    if (tabViewChild instanceof AppCompatTextView) { 
    

    to make it work with android.support.design.widget.TabLayout (at least from com.android.support:design:23.2.0)

    0 讨论(0)
  • 2020-11-27 14:14

    Create your own custom style and use parent style as parent="@android:style/TextAppearance.Widget.TabWidget"

    And in your tab layout use this style as app:tabTextAppearance="@style/tab_text"

    Example: Style:

    <style name="tab_text" parent="@android:style/TextAppearance.Widget.TabWidget">
        <item name="android:fontFamily">@font/poppins_regular</item>
    </style>
    

    Example: Tab layout component:

    <android.support.design.widget.TabLayout
            android:id="@+id/tabLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="?attr/colorPrimary"
            android:minHeight="?attr/actionBarSize"
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
            app:tabTextAppearance="@style/tab_text" />
    
    0 讨论(0)
  • 2020-11-27 14:14

    As Andrei answered, you can change fontface by extending TabLayout class. And as Penzzz said, you can't do it in addTab method. Override onLayout method as bellow:

    @Override
    protected void onLayout(boolean changed, int left, int top, int right, int bottom){
        super.onLayout(changed, left, top, right, bottom);
    
        final ViewGroup tabStrip = (ViewGroup)getChildAt(0);
        final int tabCount = tabStrip.getChildCount();
        ViewGroup tabView;
        int tabChildCount;
        View tabViewChild;
    
        for(int i=0; i<tabCount; i++){
            tabView = (ViewGroup)tabStrip.getChildAt(i);
            tabChildCount = tabView.getChildCount();
            for(int j=0; j<tabChildCount; j++){
                tabViewChild = tabView.getChildAt(j);
                if(tabViewChild instanceof AppCompatTextView){
                    if(fontFace == null){
                        fontFace = Typeface.createFromAsset(context.getAssets(), context.getString(R.string.IranSans));
                    }
                    ((TextView) tabViewChild).setTypeface(fontFace, Typeface.BOLD);
                }
            }
        }
    }
    

    Must Overwrite onLayout method, because, when you use setupWithViewPager method to bind the TabLayout with the ViewPager, you have to set tabs text either with setText method or in the PagerAdapter after that and when this happened, onLayout method get called on the parent ViewGroup (TabLayout) and that's the place to put setting fontface.(Changing a TextView text cause calling onLayout method of it's parent - A tabView has two children, one is ImageView another is TextView)

    Another Solution:

    First, these lines of code:

        if(fontFace == null){
            fontFace = Typeface.createFromAsset(context.getAssets(), context.getString(R.string.IranSans));
        }
    

    In above solution, should be written outside of two loops.

    But better solution for API >= 16 is using android:fontFamily:

    Create a Android Resource Directory named font and copy your desired font to the directory.

    Then use these styles:

    <style name="tabLayoutTitles">
        <item name="android:textColor">@color/white</item>
        <item name="android:textSize">@dimen/appFirstFontSize</item>
        <item name="android:fontFamily">@font/vazir_bold</item>
    </style>
    
    <style name="defaultTabLayout">
        <item name="android:layout_width">match_parent</item>
        <item name="android:layout_height">@dimen/defaultTabLayoutHeight</item>
        <item name="android:gravity">right</item>
        <item name="tabTextAppearance">@style/tabLayoutTitles</item>
        <item name="tabSelectedTextColor">@color/white</item>
        <item name="tabIndicatorColor">@color/white</item>
        <item name="tabIndicatorHeight">@dimen/accomTabIndicatorHeight</item>
        <item name="tabMode">fixed</item>
        <item name="tabGravity">fill</item>
        <item name="tabBackground">@drawable/rectangle_white_ripple</item>
        <item name="android:background">@color/colorPrimary</item>
    </style>
    
    0 讨论(0)
  • 2020-11-27 14:15

    For design support 23.2.0, using setupWithViewPager, you'll have to move the code from addTab(Tab tab) to addTab(Tab tab, boolean setSelected).

    0 讨论(0)
提交回复
热议问题