Viewpager 获取当前显示的fragment -- Android学习之路

原创
2016/12/03 00:02
阅读数 1.2K

sky-mxc 总结 转载注明:https://sky-mxc.github.io

Viewpager 获取当前显示的fragment

使用 getSupportFragmentManager().findFragmentByTag()方法

Viewpager + FragmentPagerAdapter 情况下 才好使; FragmentPagerAdapter 有一个特点 凡是加载过的Fragment 都会被保留,既然Fragment不会被销毁,那我们就可以使用findFragmentByTag() 方法找到它;但问题是动态创建的话 tag的设置;我们知道动态加载时是可以设置tag的,但是动态创建就没法设置了;如果viewpager使用的是适配器是 FragmentPagerAdapter 的话 ,Fragment就会被设置上tag 根据这个tag 我们就可以获取到当前显示的fragment了;下面看看这个过程

新创建时 tag ==null

@Override
public Fragment getItem(int position) {
   PageTab  pageTab = tabs.get(position);
    TabFragment tab = new TabFragment();
    Log.e(TAG,"====getItem===新创建时的tag:=="+tab.getTag());
    tab.getArguments().putSerializable("tab",pageTab);
    //取出数据 新建Fragment
    return tab;
}

Log 查看 tag 时为 null

 E/FileListPagerAdapter: ====getItem===新创建时的tag:==null

将 适配器设置给Viewpager后 的tag

E/MainActivity: ==findCurrentFragment==pagerId:2131492976
E/MainActivity: ==findCurrentFragment==currentItem:0
E/MainActivity: =======findCurrentFragment=========完整Tag===android:switcher:2131492976:0
E/MainActivity: =======findCurrentFragment=========当前显示的Fragment 的tag===:android:switcher:2131492976:0

可以看到 tag的组成;四部分
- android :      固定部分
- switcher :      固定部分
- 2131492976 :      ViewPager 的id
- 0 :      ViewPager 当前显示的itemPostion

既然FragmentPagerAdapter的特点是保存fragment状态。 就可以利用这个特点通过 findFragmentByTag() 找到这个Fragment

//Viewpager + FragmentPagerAdapter 情况下 获取 当前显示的Fragment,只能找已经加载过的Fragment
Fragment fragment =  getSupportFragmentManager().findFragmentByTag("android:switcher:"+pager.getId()+":"+pager.getCurrentItem());

重写适配器的 setPrimaryItem()方法 ;

这个方法在每次viewpager滑动后都会被调用 而 object参数就是显示的Fragment ;可以在适配器中定义个变量 currentFragment 每次改变时都会获取到显示的Fragment

@Override
public void setPrimaryItem(ViewGroup container, int position, Object object) {
    currentFragment = (TabFragment) object;
    super.setPrimaryItem(container, position, object);
}

这种方式有一个缺陷 setPrimaryItem()是在 viewpager的滑动监听执行完后才会调用的;所以在 换的个滑动监听中获取当前显示的Fragment 是不对的


展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部