TabLayout (Android Design Library) Text Color

后端 未结 9 913
面向向阳花
面向向阳花 2020-12-04 22:50

I\'m using the new TabLayout from the Android Design library. I managed to set the textcolor statelist using tabLayout.setTabTextColors(colorstatelist)

How can i ac

相关标签:
9条回答
  • 2020-12-04 23:36

    For custom tabs we have to override the following : 1) app:tabTextColor //for_unselected_text"

            <android.support.design.widget.TabLayout
                android:id="@+id/tabs"
                style="@style/MyCustomTabLayout"
                android:layout_width="match_parent"
                android:layout_height="56dp"
                android:background="?attr/colorPrimary"
                android:scrollbarSize="24sp"
                android:visibility="gone"
                app:tabTextColor="@color/white_40_percent"
                app:tabMode="scrollable" />
    

    2) tabSelectedTextColor // for selected tab color 3) tabIndicatorColor // color for tab indicator

       <style name="MyCustomTabLayout" parent="Widget.Design.TabLayout">
        <item name="android:textColorPrimary">@color/white</item>
        <item name="tabSelectedTextColor">@color/white</item>
        <item name="tabTextAppearance">@style/TabTextStyle</item>
        <item name="tabIndicatorColor">?attr/colorAccent</item>
        <item name="tabIndicatorHeight">4dp</item>
        <item name="android:tabStripEnabled">true</item>
        <item name="android:padding">0dp</item>
      </style>
    
    
    
    <style name="TabTextStyle">
        <item name="android:fontFamily">@string/font_fontFamily_medium</item>
        <item name="android:textStyle">bold</item>
        <item name="android:textAllCaps">true</item>
        <item name="android:textColor">@color/tab_text_color</item>
        <item name="android:textSize">16sp</item>
    </style>
    

    tab_text_color.xml

     <?xml version="1.0" encoding="utf-8"?>
     <selector xmlns:android="http://schemas.android.com/apk/res/android">
      <item android:color="@color/white_40_percent"android:state_selected="false"/>
      <item android:color="@color/white_100_percent"android:state_selected="true"/>
     </selector>
    
    0 讨论(0)
  • 2020-12-04 23:38

    Here is snippet code to override text style and selected text color

    <style name="MyCustomTabLayout" parent="Widget.Design.TabLayout">
        <item name="tabTextAppearance">@style/MyCustomTabText</item>
        <item name="tabSelectedTextColor">@color/tab_text_act</item>
    </style>
    
    <style name="MyCustomTabText" parent="TextAppearance.AppCompat.Button">
        <item name="android:textSize">14sp</item>
        <item name="android:textColor">@color/tab_text</item>
    </style>
    

    And here is snippet code for layout

    <android.support.design.widget.TabLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                style="@style/MyCustomTabLayout" />
    
    0 讨论(0)
  • 2020-12-04 23:38

    All the answers above are correct but I just think its better to override the default styles and only change the specific element you want to change. Example below will make the text bold:

    <style name="Widget.TabItem" parent="TextAppearance.Design.Tab">
        <item name="android:textStyle">bold</item>
    </style>
    

    Then..,

    app:tabTextAppearance="@style/Widget.TabItem"
    
    0 讨论(0)
  • 2020-12-04 23:40

    You just have to override android:textAppearance style. Because TabLayout use textAppearance. here is the small snippet code of style.

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Below will reference with our custom style -->
        <item name="android:textAppearance">@style/my_tab_text</item>
    </style>
    
    <style name="my_tab_text" parent="Base.TextAppearance.AppCompat">
        <item name="android:textColor">@android:color/holo_blue_dark</item>
    </style>
    

    And if you dont want to reference from your Apptheme you can directly specify to TabLayout using Below snippet.

     <android.support.design.widget.TabLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                app:tabTextAppearance="@style/my_tab_text"
                app:tabIndicatorHeight="48dp"/>
    
    0 讨论(0)
  • 2020-12-04 23:40

    XML attributes

    <com.google.android.material.tabs.TabLayout
                        android:id="@+id/tab_layout"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        app:tabIndicatorColor="@color/white"
                        app:tabBackground="@color/colorAccent"
                        app:tabSelectedTextColor="@color/white"
                        app:tabTextColor="@color/white"
                        app:tabMode="scrollable" />
    

    In Kotlin programmatically

    (tab_layout as TabLayout).setBackgroundColor(ContextCompat.getColor(mContext, R.color.colorPrimary))
    (tab_layout as TabLayout).setSelectedTabIndicatorColor(ContextCompat.getColor(mContext, R.color.white))
    (tab_layout as TabLayout).setTabTextColors(ContextCompat.getColor(mContext, R.color.white),
                    ContextCompat.getColor(mContext, R.color.white))
    
    0 讨论(0)
  • 2020-12-04 23:42

    Easy and Perfect way:

    In xml file ::

    <android.support.design.widget.TabLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:tabTextAppearance="@style/TabText"/>
    

    In values-styles file:

    note: "cairo_semibold" is an external font, you can replace it with your font.

    <style name="TabText" parent="TextAppearance.Design.Tab">
        <item name="android:textColor">#1f57ff</item>
        <item name="android:textSize">14sp</item>
        <item name="android:fontFamily">@font/cairo_semibold</item>
    </style>
    
    0 讨论(0)
提交回复
热议问题