我有一个使用片段和ActionBarSherlock构建的选项卡式应用程序。我有3个标签,其中有3个ListFragment,这就是正在发生的事情。
当我选择任何选项卡时,相关片段的onCreate方法将在第一时间按预期调用,但不会在第二次调用。问题是onCreate方法是为下一个相邻选项卡而不是选中选项卡调用的。
单击tab2并调用tab3的onCreate但不调用tab2。
实际上我的要求是,当我更改tab1中的某些数据时,意味着fragment1。这些更改不会在fragment2中生效,当我选择tab2(fragment2)时,它意味着fragment2 onCreate()没有调用。为什么它没有正确刷新片段。这是我正在使用的适配器。
private class TabsAdapter extends FragmentPagerAdapter implements ViewPager.OnPageChangeListener, ActionBar.TabListener {
public TabsAdapter(FragmentActivity activity, ActionBar actionBar, ViewPager pager) {
super(activity.getSupportFragmentManager());
mContext = activity;
mActionBar = actionBar;
mViewPager = pager;
mViewPager.setAdapter(this);
mViewPager.setOnPageChangeListener(this);
}
public void addTab(ActionBar.Tab tab, Class<?> clss, int tabId) {
mTabs.add(clss.getName());
mTabsId.add(tabId);
mActionBar.addTab(tab.setTabListener(this));
notifyDataSetChanged();
}
public Integer getIdForPosition(int position) {
if (position >= 0 && position < mTabsId.size()) {
return mTabsId.get(position);
}
return null;
}
@Override
public int getCount() {
return mTabs.size();
}
@Override
public Fragment getItem(int position) {
//TabInfo info = mTabs.get(position);
return Fragment.instantiate(mContext, mTabs.get(position), new Bundle());
}
@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
Log.i(TAG, "*******tab selected*******" +tab);
clearDetails();
if (mViewPager.getCurrentItem() != tab.getPosition()) {
mViewPager.setCurrentItem(tab.getPosition(), true);
}
}
@Override
public void onPageSelected(int position) {
mActionBar.setSelectedNavigationItem(position);
if (mCurrentPosition == position) {
}
mNextPosition = position;
}
@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) {
}
@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) {
}
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
答案 0 :(得分:3)
来自this page:
用户访问的每个页面的片段将保存在内存中, 虽然它的视图层次结构可能在不可见时被销毁。
这意味着用户看不到的片段仍然保留在内存中,因此在重新显示时不会调用onCreate方法。通过将ViewPager的offscreen page limit设置为0,可以在切换页面时强制它们被踢出内存。
更好的方法可能是使用片段之间共享的某种外部数据模型,然后使用onPageSelected方法告诉Fragment在进入视图时根据数据模型自行更新。
答案 1 :(得分:1)
当您使用标签:( n)时,只有标签:(n-1)和标签:(n + 1)将在内存中存活,用于内存使用优化。休息所有标签都将被销毁,这就是为什么当你回到第一个标签时,它的onCreateView
再次被调用。
实际上标签:1 的onCreateView
即使您点击标签:2 也会被调用,因为它是邻居标签。
我得到的一个解决方案是:
更改OffscreenPageLimit
的{{1}}。其默认值为ViewPager
尝试将其更改为1
。应该工作。但如果它没有
使用回拨
0