zoukankan      html  css  js  c++  java
  • FragmentPagerAdapter 刷新

    在fragmentpageadapter的instantiateItem方法里,首先设置此Fragment的标记,然后从FragmentManager中的mAdded集合里面去查找有没有相关标记的fragment如果有就直接从集合中获取使用如果没有才会触发fragmentpageadapter的getItem方法获取一个fragment。所以更新adapter数据是没有作用的

    String name = makeFragmentName(container.getId(), itemId);   //设置fragment标记  
            Fragment fragment = mFragmentManager.findFragmentByTag(name); //从mAdded中查找  
            if (fragment != null) {  
                if (DEBUG) Log.v(TAG, "Attaching item #" + itemId + ": f=" + fragment);  
                mCurTransaction.attach(fragment);  
            } else {  
                fragment = getItem(position);  
                if (DEBUG) Log.v(TAG, "Adding item #" + itemId + ": f=" + fragment);  
                mCurTransaction.add(container.getId(), fragment,  
                        makeFragmentName(container.getId(), itemId));  
            }  

    解决思路:

    1,重新创建新类继承继承PagerAdapter,创建集合mFragments
    2,将新创建的Fragment的添加到mFragments集合中
    3,在数据变化(notifyDataSetChanged)的时候,将mFragments集合清空,在instantiateItem函数里面判断有无缓存的时候加mFragments判断

    String name = makeFragmentName(container.getId(), itemId);  
    Fragment fragment = mFragmentManager.findFragmentByTag(name);  
    if (fragment != null && mFragments != null && mFragments.containsKey(position)) {  
        if (DEBUG) android.util.Log.v(TAG, "Attaching item #" + itemId + ": f=" + fragment);  
        mCurTransaction.attach(fragment);  
    } else {  
        try {  
            if (fragment != null) {  
                mCurTransaction.remove(fragment);  
            }  
            fragment = getItem(position);  
            if (DEBUG) Log.v(TAG, "Adding item #" + itemId + ": f=" + fragment);  
            mCurTransaction.add(container.getId(), fragment,  
                    makeFragmentName(container.getId(), itemId));  
            mFragments.put(position, fragment);  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
    }  
    

      

    代码下载:http://download.csdn.net/detail/xueqiang911226/9683426

  • 相关阅读:
    最短路之浇水
    agc031_d A Sequence of Permutations
    loj 3236 [POI2019 R1] Układ scalony
    CodeForces 1237H Balanced Reversals
    CodeForces 1320F Blocks and Sensors
    CodeForces 1340D Nastya and Time Machine
    agc037_f Counting of Subarrays
    nikkei2019_2_qual_e Non-triangular Triplets
    CodeForces 603E Pastoral Oddities
    Vue router / ElementUI,Ant Design Vue 重复点击导航路由报错解决方法
  • 原文地址:https://www.cnblogs.com/xueqiang911226/p/6065771.html
Copyright © 2011-2022 走看看