美文网首页Fragment
更新及替换ViewPager中的Fragment 遇到的坑

更新及替换ViewPager中的Fragment 遇到的坑

作者: 秋缘未了 | 来源:发表于2017-03-23 17:24 被阅读2388次

    下图是要实现的效果:

    星梦缘.png

    结果我实现的结果:

    QQ图片20170323170637.png QQ图片20170323170644.png

    切换上面的按钮,我希望能够通过调mAdapter.notifyDataSetChanged() 来触发 Fragment 页面使用新的数据调整或重新生成其内容,可是当我调用 notifyDataSetChanged() 后,发现什么都没发生。fragment的内容并没有刷新,尝试各种方法,清空数据,还是不会更换之前的内容

    查了下资料:

    viewpager和它的adapter是如何配合工作的?

    Android.support.v4.app.ViewPager有两个adapter:
    FragmentPagerAdapter和FragmentStatePagerAdapter:

    android.support.v4.app.FragmentPagerAdapter继承自android.support.v4.view.PagerAdapter,每页都是一个Fragment,并且所有的Fragment实例一直保存在Fragment manager中。所以它适用于少量固定的fragment,比如一组用于分页显示的标签。除了当Fragment不可见时,它的视图层(view hierarchy)有可能被销毁外,每页的Fragment都会被保存在内存中。
    android.support.v4.app.FragmentStatePagerAdapter继承自android.support.v4.view.PagerAdapter,每页都是一个Fragment,当Fragment不被需要时(比如不可见),整个Fragment都会被销毁,除了saved state被保存外(保存下来的bundle用于恢复Fragment实例)。所以它适用于很多页的情况。

    FragmentPagerAdapter和FragmentStatePagerAdapter对Fragment的管理略有不同,在详细考察二者区别之前,我们通过两种较为直观的方式先感受下:

    FragmentPagerAdapter 继承自 PagerAdapter,该类内的每一个生成的 Fragment 都将保存在内存之中,因此适用于那些相对静态的页,数量也比较少的那种;

    FragmentStatePagerAdapter 继承自 PagerAdapter,当页面离开视线后,就会被消除,释放其资源;而在页面需要显示时,生成新的页面(就像 ListView 的实现一样)。这么实现的好处就是当拥有大量的页面时,不必在内存中占用大量的内存。

    解决方案:

    不用 FragmentPagerAdapter,而改用 FragmentStatePagerAdapter,并且重载 **getItemPosition() **并返回 POSITION_NONE,以触发销毁对象以及重建对象。从上面的分析中看,后者给出的建议确实可以达到调用 notifyDataSetChanged() 后,Fragment 被以新的参数重新建立的效果。

    package com.xzqn.zhongchou.adapter;
    
    
    
    import android.support.v4.app.Fragment;
    import android.support.v4.app.FragmentManager;
    import android.support.v4.app.FragmentPagerAdapter;
    import android.support.v4.app.FragmentStatePagerAdapter;
    import android.support.v4.app.FragmentTransaction;
    import android.support.v4.view.PagerAdapter;
    
    import com.xzqn.zhongchou.base.BaseFragment;
    import com.xzqn.zhongchou.fragment.ActorDetailFm;
    
    import java.util.ArrayList;
    
    /**
     * Created by junzhu on 2017/03/23.
     */
    
    
    public class FragmentDreamAdapter extends FragmentStatePagerAdapter {
        private ArrayList<BaseFragment> fragments;
        private FragmentManager fm;
        public FragmentDreamAdapter(FragmentManager fm, ArrayList<BaseFragment> fragments) {
            super(fm);
            this.fm = fm;
            this.fragments = fragments;
            notifyDataSetChanged();
        }
    
    
        @Override
        public int getItemPosition(Object object) {
            return PagerAdapter.POSITION_NONE;
        }
    
        @Override
        public Fragment getItem(int arg0) {
            return fragments.get(arg0);
        }
    
        @Override
        public int getCount() {
            return fragments.size();
        }
    }
    

    以下是viewpager的代码

    
        private void GetRedData(String cate_id) {
    
            RequestParams params = new RequestParams(Constants.BASEURL_NEW + "notice/cate/cate_id/" + cate_id);
            params.addHeader("token", BaseApplication.getInstance().getLoginUser().getToken());
            params.addHeader("platform", "android");
            params.addHeader("version", Constants.VersionCode);
            x.http().post(params, new Callback.CommonCallback<String>() {
    
                @Override
                public void onSuccess(String result) {
                    try {
                        Gson gson = new Gson();
                        DreamTabTitleBean dreamTabTitleBean = gson.fromJson(result, DreamTabTitleBean.class);
    
                        if (titleList_red.size() > 0) {
                            titleList_red.clear();
                        }
                        fragmentList.clear();
                        LogUtils.e("fragmentList red",fragmentList+"");
                        LogUtils.e("titleList_red red",titleList_red+"");
                        //有多少个标题就有多少个碎片,动态添加
                        for (int i = 0; i < dreamTabTitleBean.getCate_list().size(); i++) {
                            titleList_red.add(dreamTabTitleBean.getCate_list().get(i).getName());
                            int flag = Integer.parseInt(dreamTabTitleBean.getCate_list().get(i).getId());
                            Dream_red_peopleFragment testFm1 = new Dream_red_peopleFragment().newInstance(titleList_red, flag);
                            fragmentList.add(testFm1);
                        }
    
                        FragmentDreamAdapter fragmentDreamAdapter = new FragmentDreamAdapter(getActivity().getSupportFragmentManager(), fragmentList);
                        mViewPager.removeAllViews();
                        mViewPager.removeAllViewsInLayout();
    
                        mViewPager.setAdapter(fragmentDreamAdapter);//new FragmentDreamAdapter(getActivity().getSupportFragmentManager(), fragmentList)
    
                        tab.setupWithViewPager(mViewPager);
                        tab.setTabMode(TabLayout.MODE_FIXED);
                        for (int i = 0; i < titleList_red.size(); i++) {
                            tab.getTabAt(i).setText(titleList_red.get(i));
                        }
    
                        onFinished();
                    } catch (Exception e) {
                        LogUtils.showErrorTip(e.getCause());
                        onError(null, false);
                    }
                }
    
                @Override
                public void onError(Throwable ex, boolean isOnCallback) {
                    LogUtils.showErrorTip(ex);
                }
    
    
                @Override
                public void onCancelled(CancelledException cex) {
    
                }
    
                @Override
                public void onFinished() {
                }
            });
    
    
        }
    

    实现的效果:

    demo.gif

    填充测试数据后的效果:

    最终效果.gif

    如果代码中有什么问题,也欢迎大家评判指出!

    相关文章

      网友评论

      • 水明::kissing_heart: 感谢作者~
      • MWTso:不错哦,一直在关注你呢。

      本文标题:更新及替换ViewPager中的Fragment 遇到的坑

      本文链接:https://www.haomeiwen.com/subject/lddtottx.html