我有一个包含4个标签的tablayout。当我选择一个标签时,该标签的文字和图标应为红色,其他标签应为灰色。
要更新图标,我创建了两个不同的版本,并在我重写的OnTabSelectedListener中更新它,但是当我将它添加到tablayout时,文本颜色似乎“落后”。最后选择的选项卡文本仍为红色,在我按下另一个新选项卡之前不会更新。
当我删除OnTabSelectedListener时,颜色正常,但我无法更新图标...我无法直接在tabLayout.tab项目上更新文本颜色。
这是Android中的错误还是我错过了什么?
activity_tab.xml:
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="com.example.oivind.tabsexample.TabActivity">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@android:color/darker_gray"/>
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabIndicatorHeight="0dp"
app:tabTextColor="@android:color/darker_gray"
app:tabSelectedTextColor="@android:color/holo_red_light"
android:background="@android:color/white"
style="@style/NASTabLayout">
</android.support.design.widget.TabLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent" />
tabActivity.java onCreate:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_tab);
mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager());
viewPager = (ViewPager) findViewById(R.id.container);
viewPager.setAdapter(mSectionsPagerAdapter);
TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
tabLayout.setupWithViewPager(viewPager);
tabLayout.getTabAt(0).setIcon(R.drawable.ic_icon_error);
for(int i = 1; i < tabLayout.getTabCount(); i++) {
tabLayout.getTabAt(i).setIcon(R.drawable.ic_icon_error_grey);
}
tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
tab.setIcon(R.drawable.ic_icon_error);
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
tab.setIcon(R.drawable.ic_icon_error_grey);
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
tab.setIcon(R.drawable.ic_icon_error_grey);
}
});
}
答案 0 :(得分:0)
我也遇到了这个错误,我通过在{strong> onTabSelected 的末尾添加tabLayout.setScrollPosition(tab.getPosition(),0f,true);
来解决此问题:
tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
tab.setIcon(navActiveIcons[tab.getPosition()]);
tabLayout.setScrollPosition(tab.getPosition(),0f,true);
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
tab.setIcon(navIcons[tab.getPosition()]);
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
}
});
答案 1 :(得分:-1)
这是一个快速修复并且无法解决原始问题
通过循环选项卡并在每次点击时设置灰色图标来修复它:
tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
for(int i = 0; i < tabLayout.getTabCount(); i++) {
tabLayout.getTabAt(i).setIcon(R.drawable.ic_icon_error_grey);
}
tab.setIcon(R.drawable.ic_icon_error);
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
}
});
如果有人知道如何正确地做到这一点,请告诉我。 :)