主布局
<?xml version="1.0" encoding="utf-8"?>
<androidx.appcompat.widget.LinearLayoutCompat xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<com.google.android.material.appbar.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
>
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
/>
<com.google.android.material.tabs.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabIndicatorColor="@color/design_default_color_primary_dark"
app:tabMode="scrollable"
/>
</com.google.android.material.appbar.AppBarLayout>
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</androidx.appcompat.widget.LinearLayoutCompat>
TabLayoutActivity
public class TabLayoutActivity extends AppCompatActivity {
private TabLayout tabLayout;
private ViewPager viewPager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_tab);
tabLayout = findViewById(R.id.tabs);
viewPager = findViewById(R.id.viewpager);
Toolbar toolbar = findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
initViewPager();
}
private void initViewPager() {
List<String> titles = new ArrayList();
titles.add("精选");
titles.add("体育");
titles.add("巴萨");
titles.add("购物");
titles.add("明星");
titles.add("视频");
titles.add("健康");
titles.add("励志");
titles.add("图文");
titles.add("本地");
titles.add("动漫");
titles.add("搞笑");
titles.add("精选");
for (String title : titles) {
tabLayout.addTab(tabLayout.newTab().setText(title));
}
List<Fragment> fragments = new ArrayList<>();
for (String title : titles) {
fragments.add(DemoFragment.newInstance(title));
}
FragmentPagerAdapter adapter = new FragmentAdapter(
getSupportFragmentManager(),fragments,titles,0
);
// 设置 ViewPager 适配器
viewPager.setAdapter(adapter);
// TabLayout 与 ViewPager 绑定
tabLayout.setupWithViewPager(viewPager);
}
}
ViewPager适配器
public class FragmentAdapter extends FragmentPagerAdapter {
private List<Fragment> fragments;
private List<String> titles;
public FragmentAdapter(@NonNull FragmentManager fm, List<Fragment> fragments, List<String> titles, int behavior) {
super(fm, behavior);
this.fragments = fragments;
this.titles = titles;
}
@NonNull
@Override
public Fragment getItem(int position) {
return fragments.get(position);
}
@Override
public int getCount() {
return fragments.size();
}
@Nullable
@Override
public CharSequence getPageTitle(int position) {
return titles.get(position);
}
}
Fragment 内容
public class DemoFragment extends Fragment {
private static final String TITLE = "title";
private String mTitle;
public DemoFragment() {
}
public static DemoFragment newInstance(String param1) {
DemoFragment fragment = new DemoFragment();
Bundle args = new Bundle();
args.putString(TITLE, param1);
fragment.setArguments(args);
return fragment;
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (getArguments() != null) {
mTitle = getArguments().getString(TITLE);
}
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View contentView =inflater.inflate(R.layout.fragment_demo, container, false);
TextView titleView = contentView.findViewById(R.id.tv_title);
titleView.setText(mTitle == null? "xx":mTitle);
return contentView;
}
}