滑动标签页

181 阅读1分钟

「这是我参与11月更文挑战的第9天,活动详情查看:2021最后一次更文挑战」 通过TabLayout和ViewPager和Fragment配合使用。

TabLayout

放标签用的。

    <com.google.android.material.tabs.TabLayout
        android:id="@+id/tabLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

ViewPager

用来存放Fragment

    <androidx.viewpager.widget.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

自定义适配器。

注:这里要重写getPageTitle,因为在TabLayout中会在绑定ViewPager后将标签清空,然后从适配器中获得标签。

package com.study.soulhouse;

import android.view.View;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentManager;
import androidx.fragment.app.FragmentPagerAdapter;
import androidx.viewpager.widget.PagerAdapter;

import java.util.List;
public class myPagerAdapter extends FragmentPagerAdapter {
    private List<Fragment> list;
    String[] tabs;
    public myPagerAdapter(@NonNull FragmentManager fm,List<Fragment> list,String[] tabs) {
        super(fm);
        this.list=list;
        this.tabs=tabs;
    }
    @NonNull
    @Override
    public Fragment getItem(int position) {
        return list.get(position);
    }
    @Override
    public int getCount() {
        return list.size();
    }
    @Nullable
    @Override
    public CharSequence getPageTitle(int position) {
       return tabs[position];
    }
}

为Viewpager绑定适配器。

package com.study.soulhouse;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentManager;
import androidx.viewpager.widget.PagerAdapter;
import androidx.viewpager.widget.ViewPager;
import androidx.viewpager2.widget.ViewPager2;

import android.os.Bundle;
import android.view.View;

import com.google.android.material.tabs.TabLayout;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        TabLayout tabLayout = findViewById(R.id.tabLayout);
        String tabs[]=new String[]{
          "推荐","电台"
        };
        for(int i=0; i<tabs.length; i++){
            tabLayout.addTab(tabLayout.newTab().setText(tabs[i]));
        }
        ViewPager viewPager = findViewById(R.id.viewPager);
        tabLayout.setupWithViewPager(viewPager);
        Fragment fragment1= new recommendFragment();
        Fragment fragment2=new radioFragment();
        List<Fragment> list=new ArrayList<Fragment>();
        list.add(fragment1);
        list.add(fragment2);
        myPagerAdapter myPagerAdapter=new myPagerAdapter(getSupportFragmentManager(),list,tabs);
        viewPager.setAdapter(myPagerAdapter);
    }
}