java - 更改所选选项卡中的文本颜色

标签 java android tabs android-tabs

我的应用程序中的选项卡出现问题。当我选择一个选项卡时,我想更改其图标和文本颜色。当我切换到另一个选项卡时,图标和文本颜色需要更改为中性色。

我尝试这样做,但虽然图标确实发生了变化,但文本颜色保持不变。

final TabLayout tabs = (TabLayout) findViewById(R.id.tabs);
tabs.addTab(tabs.newTab().setIcon(R.mipmap.destacados_act).setText("Destacados"));
tabs.setSelectedTabIndicatorColor(Color.rgb(255,170,0));
tabs.addTab(tabs.newTab().setIcon(R.mipmap.secciones).setText("Secciones"));
tabs.addTab(tabs.newTab().setIcon(R.mipmap.descargas).setText("Descargas"));

final ViewPager view_pager = (ViewPager) findViewById(R.id.pager);
final ViewPagerAdapterPrincipal adapter = new ViewPagerAdapterPrincipal(getSupportFragmentManager(), tabs.getTabCount());
view_pager.setAdapter(adapter);
view_pager.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tabs));

tabs.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
    @Override
    public void onTabSelected(TabLayout.Tab tab) {
        view_pager.setCurrentItem(tab.getPosition());

        switch (tab.getPosition()) {
            case 0:
                tab.setIcon(R.mipmap.destacados_act);
                tabs.setSelectedTabIndicatorColor(Color.rgb(255,170,0));
                break;
            case 1:
                tab.setIcon(R.mipmap.secciones_act);
                tabs.setSelectedTabIndicatorColor(Color.rgb(0,255,255));
                break;
            case 2:
                tab.setIcon(R.mipmap.descargas_act);
                tabs.setSelectedTabIndicatorColor(Color.rgb(170,255,0));
                break;
        }
    }
    public void onTabUnselected(TabLayout.Tab tab) {

        switch (tab.getPosition()) {
            case 0:
                tab.setIcon(R.mipmap.destacados);
                break;
            case 1:
                tab.setIcon(R.mipmap.secciones);
                break;
            case 2:
                tab.setIcon(R.mipmap.descargas);
                break;
        }
    }
    public void onTabReselected(TabLayout.Tab tab) {
    }
});

这是我的适配器代码

public class ViewPagerAdapterPrincipal extends FragmentStatePagerAdapter {

    int numOfTabs;

    public ViewPagerAdapterPrincipal(FragmentManager fm, int numOfTabs) {

        super(fm);
        this.numOfTabs = numOfTabs;
    }

    public Fragment getItem(int position) {

        switch(position){
            case 0 :
                DestacadosPrincipal tab1 = new DestacadosPrincipal();
                return tab1;
            case 1 :
                Secciones tab2 = new Secciones();
                return tab2;
            case 2 :
                Descargas tab3 = new Descargas();
                return tab3;
            default:
                return null;
        }
    }

    public int getCount() {
        return numOfTabs;
    }
}

问题来了 OnTabUnselected 如果我删除
tab.setIcon(); 文本颜色很好,但显然图标没有改变。

最佳答案

您可以使用选择器为选项卡上的 TextView 设置样式

这假设您使用了包含带有 style="@style/tabText"的 TextView 的自定义选项卡布局。

values/styles.xml

<style name="tabText">
    <item name="android:textColor">@drawable/text_selector_tab</item>
    <item name="android:textSize">@dimen/fontTab</item>
    <item name="android:textAllCaps">true</item>
</style>

然后使用选择器设置文本颜色:

drawable/text_selector_tab.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_selected="true" android:color="@color/colorSelected" />
    <item android:color="@color/colorDeselected" />
</selector>

然后设置选定和未选定状态的颜色属性(即此处显示为 colorSelected 和 colorDeselected。

您可以使用自定义布局自定义选项卡:

layoutTab = (LinearLayout)inflater.inflate(R.layout.layout_tab, null);
TabLayout.Tab tab = mTabLayout.newTab();
tab.setCustomView(layoutTab);
mTabLayout.addTab(tabHome);

layout/layout_tab.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_height="match_parent"
    android:layout_width="wrap_content"
    android:orientation="horizontal"
    android:gravity="center"
    android:clipToPadding="false">

    <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        style="@style/tabText" />

 </LinearLayout>

这就是选项卡中的 TextView 与样式绑定(bind)的方式。您可以深入研究平台 SDK 中的标准选项卡布局 XML,了解图标和文本的工作原理,并相应地调整此布局。

关于java - 更改所选选项卡中的文本颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42114566/

相关文章:

eclipse - 如何更改 Eclipse 以使用空格而不是制表符?

java - 应用程序因使用 com.github.glomadrian.materialanimatedswitch.MaterialAnimatedSwitch 而崩溃

java - GridBagLayout:最后一个组件影响网格宽度

java - 如何在 RecyclerView 中使用的字符串上使用自定义字体?

android - 如何使用Kotlin创建自定义 View 的构造函数

sd卡上的Android KitKat 4.4文件夹

java - Android 应用程序 - 从 Activity 绘制位图

java - 从 android studio 中的 string.xml 获取信息不起作用

tabs - 在 XPage 中进行部分刷新时 Bootstrap 选项卡会重置

java - 用作按钮的 Android 选项卡