TabLayout + ViewPager + Fragment 实现动态框架

本文介绍了一种使用TabLayout和ViewPager结合Fragment实现动态导航栏的方法。通过简单的代码示例展示了如何快速搭建具备流畅切换效果的应用界面,并提供了Fragment工厂类简化实例创建过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


TabLayout + ViewPager + Fragment 实现动态框架

先看一下效果图

图片

相信大家RadioGroup+ViewPager或者FragmentTabHost+ViewPager
的实现方式大家都知道了,关于这个TabLayout+ViewPager
我只想说太他妈容易实现我们想要的效果了


使用之前要说的:需要导入依赖,

 compile 'com.android.support:appcompat-v7:24.2.0'
 compile 'com.android.support:design:24.2.0'
 compile files('libs/butterknife-7.0.0.jar')

三个Fragment 格式一样,这里我就放一个吧

package com.oblivion.tablayout.fragment;

import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

/**
 * github : https://github.com/oblivion0001/AndroidStudioProjects
 * Blog : http://blog.youkuaiyun.com/qq_16666847
 * Created by oblivion on 2016/11/22.
 */
public class HomeFragment extends Fragment {
    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        TextView tv = new TextView(getContext());
        tv.setText(getClass().getSimpleName());
        tv.setGravity(Gravity.CENTER);
        return tv;
    }
}

为了方便使用Fragment我创建了简单的Fragment工厂


package com.oblivion.tablayout.fragmentfactory;

import android.support.v4.app.Fragment;

import com.oblivion.tablayout.fragment.AppFragment;
import com.oblivion.tablayout.fragment.HomeFragment;
import com.oblivion.tablayout.fragment.PlayFragment;

/**
 * github : https://github.com/oblivion0001/AndroidStudioProjects
 * Blog : http://blog.youkuaiyun.com/qq_16666847
 * Created by oblivion on 2016/11/22.
 */
public class FragmentFactory {
    public static Fragment getFragment(int position) {
        Fragment fragment = null;
        switch (position) {
            case 0:
                fragment = new HomeFragment();
                break;
            case 1:
                fragment = new AppFragment();
                break;
            case 2:
                fragment = new PlayFragment();
                break;
        }
        return fragment;
    }
}

接下来就是我们的实现拉

package com.oblivion.tablayout;

import android.os.Bundle;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;

import com.oblivion.tablayout.fragmentfactory.FragmentFactory;

import butterknife.Bind;
import butterknife.ButterKnife;

public class MainActivity extends FragmentActivity {

    @Bind(R.id.tab)
    TabLayout tab;
    @Bind(R.id.viewpager)
    ViewPager viewpager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ButterKnife.bind(this);
        viewpager.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tab));
        tab.setupWithViewPager(viewpager);
        setAdapter();
    }

    private void setAdapter() {
        viewpager.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {
            @Override
            public Fragment getItem(int position) {
                return FragmentFactory.getFragment(position);
            }

            @Override
            public int getCount() {
                return 3;
            }

            @Override
            public CharSequence getPageTitle(int position) {
                String[] str = new String[]{"首页", "应用", "游戏"};
                return str[position];
            }
        });
    }
}

是不是很简单源码地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值