【问题标题】:TabLayout (Android Design Library) Text ColorTabLayout(Android 设计库)文本颜色
【发布时间】:2015-09-03 17:51:50
【问题描述】:

我正在使用来自 Android 设计库的新 TabLayout。我设法使用tabLayout.setTabTextColors(colorstatelist) 设置了textcolor statelist

如何使用styles.xml 实现相同的效果?

【问题讨论】:

    标签: android android-design-library androiddesignsupport


    【解决方案1】:

    XML 属性

    <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" />
    

    以编程方式在 Kotlin 中

    (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))
    

    【讨论】:

      【解决方案2】:

      使用Material Components Library 中提供的TabLayout,您可以:

      • 使用自定义样式
        <com.google.android.material.tabs.TabLayout
            style="@style/My_Tablayout"
            ..>
      

      并按照您的风格使用带有选择器的 tabTextColor

      <!-- TabLayout -->
      <style name="My_Tablayout" parent="Widget.MaterialComponents.TabLayout" >
          <item name="tabTextColor">@color/tab_layout_selector</item>
      </style>
      
      
      <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:color="?attr/colorPrimary" android:state_selected="true"/>
        <item android:alpha="0.60" android:color="?attr/colorOnSurface"/>
      </selector>
      
      • 在您的布局中使用 app:tabTextColor
        <com.google.android.material.tabs.TabLayout
            app:tabTextColor="@color/tab_layout_selector"
            ..>
      

      【讨论】:

        【解决方案3】:

        最好的或短而简单的方法是制作自定义 appbar 之类的

         <?xml version="1.0" encoding="utf-8"?>
            <android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_width="match_parent"
            android:layout_height="?android:attr/actionBarSize"
            xmlns:app="http://schemas.android.com/apk/res-auto"
            android:background="@color/colorAccent"
            app:theme="@style/myCustomAppBarTheme"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Dark"><RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent">
        
                <ImageButton
                    android:id="@+id/btn_back"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_alignParentLeft="true"
                    android:background="@android:color/transparent"
                    android:src="@mipmap/ic_launcher" />
        
                <TextView
                    android:id="@+id/txt_title"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_centerVertical="true"
                    android:layout_marginLeft="16dp"
                    android:layout_marginStart="16dp"
                    android:layout_toEndOf="@+id/btn_back"
                    android:layout_toRightOf="@+id/btn_back"
                    android:text="Title"
                    android:textColor="@android:color/white"
                    android:textSize="20sp"
                    android:textStyle="bold" />
        
            </RelativeLayout>
            </android.support.v7.widget.Toolbar>
        

        【讨论】:

          【解决方案4】:

          简单而完美的方法:

          在xml文件中::

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

          在值样式文件中:

          注意:“cairo_semibold”是外部字体,你可以用你的字体替换它。

          <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>
          

          【讨论】:

            【解决方案5】:

            对于自定义标签,我们必须覆盖以下内容: 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 // 用于选择的标签颜色 3) tabIndicatorColor // 标签指示器的颜色

               <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>
            

            【讨论】:

              【解决方案6】:

              通过 XML 属性:

              <android.support.design.widget.TabLayout
                      android:layout_width="match_parent"
                      android:layout_height="wrap_content"
                      app:tabMode="fixed"
                      app:tabGravity="fill"
                      app:tabTextColor="@color/your_unselected_text_color"
                      app:tabSelectedTextColor="@color/your_selected_text_color"/>
              

              此外,还有 tabIndicatorColor 或 tabIndicatorHeight 等属性用于进一步的样式设置。

              在代码中:

              tabLayout.setTabTextColors(
                  getResources().getColor(R.color.your_unselected_text_color),
                  getResources().getColor(R.color.your_selected_text_color)
              );
              

              由于这种旧方式自 API 23 起已被弃用,替代方案是:

              tabLayout.setTabTextColors(
                  ContextCompat.getColor(context, R.color.your_unselected_text_color),
                  ContextCompat.getColor(context, R.color.your_selected_text_color)
              );
              

              【讨论】:

              • @Fe Le 如果我想务实地改变怎么办?
              • @pcpriyanka 感谢您的提示,我已经用一种在代码中定义选定和未选定颜色的简单方法更新了我的答案。
              【解决方案7】:

              以上所有答案都是正确的,但我认为最好覆盖默认样式并仅更改您要更改的特定元素。 下面的示例将使文本变为粗体:

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

              那么..,

              app:tabTextAppearance="@style/Widget.TabItem"
              

              【讨论】:

              • 很抱歉,您是从哪里找到这种方法的?
              【解决方案8】:

              这是覆盖文本样式和选定文本颜色的 sn-p 代码

              <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>
              

              这是用于布局的 sn-p 代码

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

              【讨论】:

              • 谢谢 - 这对我有用。就像指出 tabSelectedTextColor 是选项卡下的行的颜色和选项卡我选择时选项卡的文本。
              • 为什么要继承 Widget.Design.TabLayout ?
              • 为什么我们必须在 TabLayout 上使用“样式”?如果我使用“android:theme”为什么它不起作用?
              • @Spacemonkey 因为 Widget.Design.TabLayout 包含标签的基本样式,例如“tabIndicatorColor”、“tabIndicatorHeight”
              • @sweetrenard 哦,所以它覆盖了我在“android:theme”中指定的主题?
              【解决方案9】:

              您只需覆盖android:textAppearance 样式。因为 TabLayout 使用 textAppearance。这是样式的小sn-p代码。

              <!-- 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>
              

              并且如果您不想从您的 Apptheme 中引用,您可以使用下面的 sn-p 直接指定 TabLayout。

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

              【讨论】:

              • 确保您使用 AppCompact 作为父级
              • 好吧,你是对的,它有效。但仅适用于“未选择”选项卡。选定的标签文本对我来说总是黑色的
              • 好的,设计库中没有可用于在设计支持库中分配所选选项卡的 textColor 的代码。因此,对于选定的选项卡文本颜色,您必须使用属性 .. 进行设置
              猜你喜欢
              • 2016-05-12
              • 1970-01-01
              • 1970-01-01
              • 2015-08-12
              • 1970-01-01
              • 2015-10-02
              • 2023-03-11
              • 1970-01-01
              • 1970-01-01
              相关资源
              最近更新 更多