FragmentPagerAdapter和FragmentStatePagerAdapter之间的差别、监听器OnPageChangeListener

PagerAdapter和FragmentPagerAdapter的区别:

FragmentPagerAdapter适配器,它会把所有页面都加载进来和PagerAdapter的3个3个加载页面不一样。它里面没有动态构建选项卡和销毁选项。它适合于页面卡加载比较少的应用。

FragmentPagerAdapter的适配器:

这里写图片描述

FragmentActivity1中的代码:

这里写图片描述

这里四个FragmentActivity中的代码都是一样的,只需要改变return值中的布局添加——R.layout.view1,(R.layout.view2)等

MyFragmentPagerAdapter代码:

 public class MyFragmentPagerAdapter extends FragmentPagerAdapter {
private List<Fragment>fragmentList;
    private List<String> titlelist;
    public MyFragmentPagerAdapter(FragmentManager fm,List<Fragment>fragmentList,List<String> titlelist) {
        super(fm);
        this.fragmentList=fragmentList;
        this.titlelist=titlelist;
    }

    @Override
    public CharSequence getPageTitle(int position) {
        return titlelist.get(position);
    }

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

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

主函数中的代码是:

public class MainActivity extends FragmentActivity {
    private List<View> viewList;
    private ViewPager pager;
    private PagerTabStrip tabStrip;
    private List<String> titlelist;
    private List<Fragment> fraglist;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        viewList = new ArrayList<>();
        /**
         * 通过View对象去作为ViewPager的数据源
         */
        View view1 = View.inflate(this, R.layout.view1, null);
        View view2 = View.inflate(this, R.layout.view2, null);
        View view3 = View.inflate(this, R.layout.view3, null);
        View view4 = View.inflate(this, R.layout.view4, null);
        viewList.add(view1);
        viewList.add(view2);
        viewList.add(view3);
        viewList.add(view4);
        //为ViewPager页卡设置标题
        titlelist = new ArrayList<>();
        titlelist.add("微信");
        titlelist.add("通讯录");
        titlelist.add("发现");
        titlelist.add("我");
        //给PagerTabStrip设置一些属性
        tabStrip = (PagerTabStrip) findViewById(R.id.tab);
        tabStrip.setBackgroundColor(Color.YELLOW);
        tabStrip.setTextColor(Color.RED);
        tabStrip.setDrawFullUnderline(false);
        tabStrip.setTabIndicatorColor(Color.GREEN);

        /**
         * 通过Fragment作为ViewPager的数据源
         */
        fraglist = new ArrayList<>();
        fraglist.add(new FragmentActivity1());
        fraglist.add(new FragmentActivity2());
        fraglist.add(new FragmentActivity3());
        fraglist.add(new FragmentActivity4());
        //初始化ViewPager
        pager = (ViewPager) findViewById(R.id.viewpager);
        //创建PagerAdapter的适配器
        MyPagerAdapter myPagerAdapter = new MyPagerAdapter(viewList, titlelist);
        //ViewPager加载适配器
//        pager.setAdapter(myPagerAdapter);
        MyFragmentPagerAdapter adapter=new MyFragmentPagerAdapter(getSupportFragmentManager(),fraglist,titlelist);
        pager.setAdapter(adapter);

FragmentStatePagerAdapter和FragmentPagerAdapter的区别:

在FragmentStatePagerAdapter中是有动态销毁页卡和实例化页卡的。

FragmentStatePagerAdapter中的代码只比MyFragmentPagerAdapter中的代码多了下面两种代码:

 @Override
    public Object instantiateItem(ViewGroup container, int position) {
        return super.instantiateItem(container, position);
    }

    @Override
    public void destroyItem(View container, int position, Object object) {
        super.destroyItem(container, position, object);
    }

在这里我导入的是import.android.support.v4.app.Fragment包,而不是android.app.Fragment包;导入前面那个包在低版本以下也可以继续使用Fragment

监听器:

增加3个方法,我们最常用到的是onPageSelected()方法。

可以监听到页卡切换到的当前页卡数

代码如下:

 @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    @Override
    public void onPageSelected(int position) {
        Toast.makeText(this, "当前是第"+position+"个页面", Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onPageScrollStateChanged(int state) {

    }

最后记得在onCreate()方法中加载监听器。

 pager.setOnPageChangeListener(this);
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值