一、TabLayout+ViewPager+Fragment实现顶部的滑动标题栏
①activity页面布局
<LinearLayout 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">
<android.support.design.widget.TabLayout
android:id="@+id/tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabIndicatorColor="@color/colorPrimary"
app:tabSelectedTextColor="@color/colorPrimary"
app:tabTextColor="@color/black" />
<android.support.v4.view.ViewPager
android:id="@+id/vp"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
②适配器
package com.gu.rsyun.adapter;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import java.util.List;
/**
* Created by Gu on 2017/8/14.
*/
public class FileAdapter extends FragmentPagerAdapter {
private List<Fragment> fragmentList;
private FragmentManager fm;
private String[] titles;
public FileAdapter(List<Fragment> fragmentList, FragmentManager fm, String[] titles) {
super(fm);
this.fragmentList = fragmentList;
this.fm = fm;
this.titles = titles;
}
@Override
public Fragment getItem(int position) {
return fragmentList.get(position);
}
@Override
public int getCount() {
return fragmentList != null ? fragmentList.size() : 0;
}
@Override
public CharSequence getPageTitle(int position) {
return titles == null ? super.getPageTitle(position) : titles[position];
}
}
③TabLayout所在activity或者fragment的实现
public class FileFragment extends Fragment {
private TabLayout tabLayout;
private ViewPager vp;
private FileAdapter adapter;
private List<Fragment> list = new ArrayList<Fragment>();
private String[] titles = {"全部", "文档", "图片", "视频", "音乐"};
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_file, container, false);
initView(view);
return view;
}
private void initView(View view) {
tabLayout = (TabLayout) view.findViewById(R.id.tablayout);
vp = (ViewPager) view.findViewById(R.id.vp);
list.add(DetailFragment.newInstance("/"));
list.add(DetailFragment.newInstance("/doc/"));
list.add(DetailFragment.newInstance("/picture/"));
list.add(DetailFragment.newInstance("/video/"));
list.add(DetailFragment.newInstance("/music/"));
tabLayout.setTabMode(TabLayout.MODE_FIXED);
adapter = new FileAdapter(list, getChildFragmentManager(), titles);
vp.setAdapter(adapter);
tabLayout.setupWithViewPager(vp);
}
}
④通过反射调整下划线的宽度和文字宽度一致
//反射调整下划线宽度
private void reflex(final TabLayout tabLayout) {
//线的宽度是根据 tabView的宽度来设置的
tabLayout.post(new Runnable() {
@Override
public void run() {
try {
//拿到tabLayout的mTabStrip属性
LinearLayout mTabStrip = (LinearLayout) tabLayout.getChildAt(0);
for (int i = 0; i < mTabStrip.getChildCount(); i&#