私はメインアクティビティを持っています。これはフラグメントをホストし、それが(LayoutPagerで)TabLayoutをホストします。タブバーが表示されますが、タブ自体は表示されません。
Hostフラグメントを表示するためのメインアクティビティのコードは次のとおりです。
Fragment fragment = new BMITabsFragment();
FragmentManager fragmentManager = getSupportFragmentManager();
fragmentManager.beginTransaction().replace(R.id.content_frame, fragment).addToBackStack(Constants.BMI_TABS_FRAGMENT).commit();
これが、BMITabsFragment(s.a.)であるTabLayoutをホストする私のフラグメントです。
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>
私のコードはGoogleに基づいていますAndroid Guide at https://github.com/codepath/Android_guides/wiki/Google-Play-Style-Tabs-using-TabLayout =
ここで何が欠けていますか?
注:私はAppCompatActivityとサポートライブラリv4&v7およびcom:Android:support:designライブラリを使用しています
私は同じ問題を抱えています!しかし、この修正も私です。
tabLayout.post(new Runnable() {
@Override
public void run() {
tabLayout.setupWithViewPager(viewPager);
}
});
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]);
}
@Nathaniel Fordが言ったように、これはバグだと思います。設計ライブラリ23.0.1を使用するように変更します。Googleが修正したので、build.gradle
〜compile 'com.Android.support:design:23.0.1'
。 ps:compileSdkVersion
to 23も変更する必要があります
XmlファイルのTablayoutでAndroid:tabPadding
属性を使用している場合は、それを削除します。
他の答えはどれもうまくいかなかったので、すべて試しました
ただし、これは次のとおりです: TabLayoutはナビゲーションバーを追加した後にタブを表示しません
その答えによれば、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>
FragmentPagerAdapterの代わりにFragmentStatePagerAdapterを使用できます。それはあなたを助けるかもしれません。