【问题标题】:Tabs of TabLayout not showingTabLayout 的选项卡未显示
【发布时间】:2015-07-21 16:26:34
【问题描述】:

我有一个主要活动,它承载一个片段,而片段又承载一个 TabLayout(带有 ViewPager)。显示标签栏,但不显示标签本身。

这是我在主要活动中用于显示主机片段的代码:

        Fragment fragment = new BMITabsFragment();

        FragmentManager fragmentManager = getSupportFragmentManager();
        fragmentManager.beginTransaction().replace(R.id.content_frame, fragment).addToBackStack(Constants.BMI_TABS_FRAGMENT).commit();

这是我托管 TabLayout 的 Fragment,即 BMITabsFragment (s.a.):

public class BMITabsFragment extends Fragment {
...
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    if (getArguments() != null) {
        mParam1 = getArguments().getString(ARG_PARAM1);
        mParam2 = getArguments().getString(ARG_PARAM2);
    }

}

@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
    super.onViewCreated(view, savedInstanceState);

    // Get the ViewPager and set it's PagerAdapter so that it can display items
    ViewPager viewPager = (ViewPager) view.findViewById(R.id.viewpager);
    viewPager.setAdapter(new BMIFragmentPagerAdapter(getActivity().getSupportFragmentManager(),
            getActivity()));

    // Give the TabLayout the ViewPager
    TabLayout tabLayout = (TabLayout) view.findViewById(R.id.sliding_tabs);
    tabLayout.setupWithViewPager(viewPager);
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    // Inflate the layout for this fragment
    View view = inflater.inflate(R.layout.fragment_bmitabs, container, false);
    return view;
}
...
}

这是我的 FragmentPagerAdapter:

public class BMIFragmentPagerAdapter extends FragmentPagerAdapter {

final int PAGE_COUNT = 2;
private FragmentManager fragmentManager;
private Context context;

public BMIFragmentPagerAdapter(FragmentManager fm, Context context) {
    super(fm);
    this.context = context;
    this.fragmentManager = fm;

}

public BMIFragmentPagerAdapter(FragmentManager fm) {
    super(fm);
    fragmentManager = fm;

}

@Override
public CharSequence getPageTitle(int position) {
    String[] pageTitles = context.getResources().getStringArray(R.array.page_titles_array);
    return pageTitles[position];
}

@Override
public Fragment getItem(int position) {
    SharedPreferences prefs = context.getSharedPreferences(Constants.SHARED_PREFS_FILE, 0);
    long patientId = prefs.getLong(Constants.SELECTED_PATIENT_ID, 1);
    Fragment fragment = null;
    switch (position){
        case 0:
            return BMITabelleFragment.newInstance(patientId);

        case 1:
            return BMIChartFragment.newInstance(patientId);

        default:
            return BMITabelleFragment.newInstance(patientId);
    }
}

@Override
public int getCount() {
    return PAGE_COUNT;
}
}

这是fragment_bmitabs.xml:

<?xml version="1.0" encoding="utf-8"?>

<android.support.design.widget.TabLayout
    android:id="@+id/sliding_tabs"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:tabMode="scrollable" />

<android.support.v4.view.ViewPager
    android:id="@+id/viewpager"
    android:layout_width="match_parent"
    android:layout_height="0px"
    android:layout_weight="1"
    android:background="@android:color/white" />

</LinearLayout>

我的代码基于https://github.com/codepath/android_guides/wiki/Google-Play-Style-Tabs-using-TabLayout 上的 Google Android 指南

我在这里缺少什么?

注意:我正在使用 AppCompatActivity 以及支持库 v4 和 v7 以及 com:android:support:design 库

【问题讨论】:

  • styles.xml 中的一个简单更新 - 类似于 &lt;style name="TextAppearance.Widget.TabWidget" parent="@style/AppTheme"&gt; .. 为我工作 - 在这里回答:stackoverflow.com/a/2805256/2162226

标签: android android-fragments android-viewpager android-tablayout


【解决方案1】:

这为我解决了问题:

tabLayout.post(new Runnable() {
    @Override
    public void run() {
        tabLayout.setupWithViewPager(viewPager);
    }
});

https://code.google.com/p/android/issues/detail?id=180462

【讨论】:

  • Absurd... 文档说“此视图还支持用作 ViewPager 装饰的一部分,并且可以像这样在布局资源文件中直接添加到 ViewPager”建议如果你使用这个以这种方式查看您不需要调用该方法。
  • 对我不起作用。标签的片段仍未显示
【解决方案2】:

setupWithViewPager()之后设置标签图标

private void setTabs {
   tabLayout.setupWithViewPager(viewPager);
   setupTabIcons();
} 

private void setupTabIcons() {
   tabLayout.getTabAt(0).setIcon(tabIcons[0]);
   tabLayout.getTabAt(1).setIcon(tabIcons[1]);
   tabLayout.getTabAt(2).setIcon(tabIcons[2]);
}

【讨论】:

  • 您忘记修复此答案中的链接。现在它指向“在此处输入链接描述”。
  • 这对我有用,viewPager 已经初始化了选项卡,只需使用 getTabAt() 抓取选项卡并设置 Text、Icon 或 CustomView 即可!
【解决方案3】:

就像@Nathaniel Ford 说的,这应该是个bug,我改用设计库23.0.1。google 修复了它,所以把build.gradle 改成compile 'com.android.support:design:23.0.1'。 ps:你还必须把你的compileSdkVersion改为23

【讨论】:

  • 谢谢...这对我有用。谷歌 API 的糟糕质量一直让我感到惊讶,这简直是惊人的。
【解决方案4】:

如果您在xml文件的Tablayout中使用android:tabPadding属性,请将其删除。

【讨论】:

  • 因为这可能是一个有效的答案,请详细说明并解释原因。谢谢
【解决方案5】:

其他答案都不适合我,我都试过了

但是,这个是:TabLayout not showing tabs after adding navigation bar

根据该答案,您必须将您的TabLayout 括在AppBarLayout 中。为什么?谁知道。但至少它有效。

示例代码(取自该帖子):

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginTop="200dp"
    android:id="@+id/appBarLayout2">


    <android.support.design.widget.TabLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tabLayout2"
        app:tabMode="fixed"
        app:tabGravity="fill"

        ></android.support.design.widget.TabLayout>

</android.support.design.widget.AppBarLayout>

<android.support.v4.view.ViewPager
    android:layout_width="match_parent"
    android:layout_height="300dp"
    android:layout_alignParentStart="true"
    android:layout_alignParentBottom="true"
    android:id="@+id/viewPager2"
    android:layout_below="@+id/appBarLayout2">

</android.support.v4.view.ViewPager>

【讨论】:

    【解决方案6】:

    您可以使用 FragmentStatePagerAdapter 代替 FragmentPagerAdapter。 可能对你有帮助。

    【讨论】:

      【解决方案7】:

      如果将来有人使用 TabLayout 和 ViewPager2 并面临同样的问题。只需在new TabLayoutMediator() 末尾添加.attach();

      new TabLayoutMediator(tabLayoutRef, viewPager2Ref, (tab, position) -> tab.setText("Tab No. "+position)).attach();
      

      【讨论】:

        猜你喜欢
        • 2016-10-29
        • 1970-01-01
        • 2017-06-26
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2017-07-11
        相关资源
        最近更新 更多