ViewPager + Fragment

ViewPager经常和Fragment一起使用,并且提供了专门的FragmentPagerAdapter和FragmentStatePagerAdapter类供Fragment中的ViewPager使用。

效果图:

ViewPager + Fragment_第1张图片

ViewPager + Fragment_第2张图片


XML代码:


     
     
     
     

然后写四个碎片(Fragment),代码比较简单,这里博主就不贴代码了。

接着写四个碎片的实现类,绑定四个碎片。

最后再写最主要的一个class


Java代码:

package com.example.g160628_11_02;

import android.graphics.Color;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.TextView;

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

public class MainActivity extends FragmentActivity implements OnClickListener{

    /**
     * 四个导航
     */
    private LinearLayout lintonOne;
    private LinearLayout lintonTwo;
    private LinearLayout lintonThree;
    private  LinearLayout lintonFour;

    /**
     * 作为页面容器的ViewPager
     */
    private ViewPager mViewPager;
    /**
     * 页面集合
     */
    private List fragmentList;

    /**
     * 四个Fragment(页面)
     */
    private WeiXinFragment oneFragment;
    private ContactsFragment twoFragment;
    private FindFragment threeFragment;
    private MyFragment fourFragment;


    //当前选中的项
    private int currenttab=-1;
    private TextView tvweixin;
    private TextView tvcontact;
    private TextView tvfind;
    private TextView tvmy;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);


        setContentView(R.layout.activity_main);
        lintonOne= (LinearLayout) findViewById(R.id.lin_one);
        lintonTwo=(LinearLayout) findViewById(R.id.lin_two);
        lintonThree=(LinearLayout) findViewById(R.id.lin_three);
        lintonFour=(LinearLayout) findViewById(R.id.lin_four);


        tvweixin = (TextView) findViewById(R.id.tv_weixin);
        tvcontact = (TextView) findViewById(R.id.tv_contact);
        tvfind = (TextView) findViewById(R.id.tv_find);
        tvmy = (TextView) findViewById(R.id.tv_my);


        lintonOne.setOnClickListener(this);
        lintonTwo.setOnClickListener(this);
        lintonThree.setOnClickListener(this);
        lintonFour.setOnClickListener(this);

        mViewPager=(ViewPager) findViewById(R.id.viewpager);

        fragmentList=new ArrayList();
        oneFragment=new WeiXinFragment();
        twoFragment=new ContactsFragment();
        threeFragment=new FindFragment();
        fourFragment=new MyFragment();

        fragmentList.add(oneFragment);
        fragmentList.add(twoFragment);
        fragmentList.add(threeFragment);
        fragmentList.add(fourFragment);

        mViewPager.setAdapter(new MyFrageStatePagerAdapter(getSupportFragmentManager()));

        tvweixin.setTextColor(Color.RED);
    }


    /**
     * 定义自己的ViewPager适配器。
     * 也可以使用FragmentPagerAdapter。关于这两者之间的区别,可以自己去搜一下。
     */
    class MyFrageStatePagerAdapter extends FragmentStatePagerAdapter
    {

        public MyFrageStatePagerAdapter(FragmentManager fm)
        {
            super(fm);
        }

        @Override
        public Fragment getItem(int position) {
            return fragmentList.get(position);
        }

        @Override
        public int getCount() {
            return fragmentList.size();
        }

        /**
         * 每次更新完成ViewPager的内容后,调用该接口,此处复写主要是为了让导航按钮上层的覆盖层能够动态的移动
         */
        @Override
        public void finishUpdate(ViewGroup container)
        {
            super.finishUpdate(container);//这句话要放在最前面,否则会报错
            //获取当前的视图是位于ViewGroup的第几个位置,用来更新对应的覆盖层所在的位置
            int currentItem=mViewPager.getCurrentItem();
            if (currentItem==currenttab)
            {
                return ;
            }
            //    imageMove(mViewPager.getCurrentItem());
            currenttab=mViewPager.getCurrentItem();
            if (currenttab==0){
                tvweixin.setTextColor(Color.RED);
            }else{
                tvweixin.setTextColor(Color.BLACK);
            }
            if (currenttab==1){
                tvcontact.setTextColor(Color.RED);
            }else{
                tvcontact.setTextColor(Color.BLACK);
            }
            if (currenttab==2){
                tvfind.setTextColor(Color.RED);
            }else{
                tvfind.setTextColor(Color.BLACK);
            }
            if (currenttab==3){
                tvmy.setTextColor(Color.RED);
            }else{
                tvmy.setTextColor(Color.BLACK);
            }
        }

    }
    @Override
    public void onClick(View v)
    {
        switch (v.getId())
        {
            case R.id.lin_one:
                changeView(0);
                break;
            case R.id.lin_two:
                changeView(1);
                break;
            case R.id.lin_three:
                changeView(2);
                break;
            case R.id.lin_four:
                changeView(3);
                break;
            default:
                break;
        }
    }
    //手动设置ViewPager要显示的视图
    private void changeView(int desTab)
    {
        mViewPager.setCurrentItem(desTab, true);
    }

}

你可能感兴趣的:(ViewPager + Fragment)