Zol*_*tar 4 tabs android fragment oncreate android-fragments
这是android studio在选择3选项卡式布局时自动生成的代码.问题是,当它开始在第一个选项卡,它会调用onCreateView在class PlaceholderFragment.当我切换到第二个选项卡时,它再次为该选项卡调用它.现在问题从返回tab1开始,它不会调用onCreateView.现在,如果我转到tab3,它将被调用该选项卡,然后返回到tab1它现在被调用.因此,onCreateView如果我从tab2转到tab1但是从tab3调到tab1,那么tab1 永远不会被调用.我无法弄清楚为什么它不会仅仅在特定的序列中破坏这个视图.
我没有修改这个自动生成的代码,所以我认为它会正常工作.
public class MainActivity extends ActionBarActivity implements ActionBar.TabListener {
SectionsPagerAdapter mSectionsPagerAdapter;
ViewPager mViewPager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final ActionBar actionBar = getSupportActionBar();
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager());
mViewPager = (ViewPager) findViewById(R.id.pager);
mViewPager.setAdapter(mSectionsPagerAdapter);
mViewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
@Override
public void onPageSelected(int position) {
actionBar.setSelectedNavigationItem(position);
}
});
for (int i = 0; i < mSectionsPagerAdapter.getCount(); i++) {
actionBar.addTab(
actionBar.newTab()
.setText(mSectionsPagerAdapter.getPageTitle(i))
.setTabListener(this));
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
public void onTabSelected(ActionBar.Tab tab, FragmentTransaction fragmentTransaction) {
mViewPager.setCurrentItem(tab.getPosition());
}
@Override
public void onTabUnselected(ActionBar.Tab tab, FragmentTransaction fragmentTransaction) {
}
@Override
public void onTabReselected(ActionBar.Tab tab, FragmentTransaction fragmentTransaction) {
}
public class SectionsPagerAdapter extends FragmentPagerAdapter {
public SectionsPagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
return PlaceholderFragment.newInstance(position + 1);
}
@Override
public int getCount() {
// Show 3 total pages.
return 3;
}
@Override
public CharSequence getPageTitle(int position) {
Locale l = Locale.getDefault();
switch (position) {
case 0:
return getString(R.string.title_section1).toUpperCase(l);
case 1:
return getString(R.string.title_section2).toUpperCase(l);
case 2:
return getString(R.string.title_section3).toUpperCase(l);
}
return null;
}
}
public static class PlaceholderFragment extends Fragment {
private static final String ARG_SECTION_NUMBER = "section_number";
public static PlaceholderFragment newInstance(int sectionNumber) {
PlaceholderFragment fragment = new PlaceholderFragment();
Bundle args = new Bundle();
args.putInt(ARG_SECTION_NUMBER, sectionNumber);
fragment.setArguments(args);
return fragment;
}
public PlaceholderFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_main, container, false);
return rootView;
}
}
Run Code Online (Sandbox Code Playgroud)
}
Par*_* P. 15
Viewpager有一个名为setOffScreenPageLimit()的公共方法,它指示在空闲状态下将保留到视图层次结构中当前页面任一侧的页面数.
当你使用setOffscreenPageLimit()的默认实现时,它只加载它右边的一个片段.
例如,如果您当前在index1上,它在内存中加载索引2但不在索引0中加载,因此向左滑动将从头开始加载新片段.使用setOffScreenLimit(1),setOffScreenLimit(2)等它将有助于清除您对该概念的疑虑.
| 归档时间: |
|
| 查看次数: |
2549 次 |
| 最近记录: |