TabLayout实现顶部标题栏和底部导航栏,TrustyGridSimpleAdapter实现按日分类图片

本文详细介绍了如何在Android应用中使用TabLayout+ViewPager+Fragment构建滑动标题栏,以及利用TabLayout+ViewPager实现底部导航栏。此外,还讲解了TrustyGridSimpleAdapter的使用,包括如何添加jar包以及如何将时间戳转换为可读日期,以实现按日分类展示图片的功能。
摘要由CSDN通过智能技术生成

一、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&#
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值