jes*_*.tt 5 android android-fragments android-viewpager
好的,所以我正在尝试实现一个包含三个页面的 ViewPager,并且每个页面都有独特的内容,所以我建立了一个系统,我根据页面索引膨胀不同的布局。这在我导航后立即起作用,但我注意到 Fragment 被调用了两次。
这是我的 FragmentAcivity 类:
public class TutorialScreen extends FragmentActivity {
private static final String TAG = "TAG";
private static final int NUM_PAGES = 3;
private ViewPager pager; // animation handler
private PagerAdapter adapter; // provides pages to pager
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.tutorial_layout);
// Instantiate Pager & Adapter
pager = (ViewPager) findViewById(R.id.pager);
adapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());
pager.setAdapter(adapter);
Log.v(TAG, "Initial Page is " + pager.getCurrentItem()); // this logs '0' - which is what i want
pager.setCurrentItem(pager.getCurrentItem());
}
@Override
public void onBackPressed() {
if(pager.getCurrentItem() == 0) {
super.onBackPressed();
}
else {
pager.setCurrentItem(pager.getCurrentItem() -1);
}
}
// Pager Adapter SubClass
private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
public ScreenSlidePagerAdapter(FragmentManager fm) {
super(fm);
Log.v(TAG, "constructor"); // this logs once
pager.setCurrentItem(pager.getCurrentItem());
}
@Override
public Fragment getItem(int position) {
Log.v(TAG, "getItem " + position); // this logs twice
return new ScreenSlidePageFragment(position); // note I've overridden the constructor
}
@Override
public int getCount() {
return NUM_PAGES;
}
}
}
Run Code Online (Sandbox Code Playgroud)
和我的片段类:
public class ScreenSlidePageFragment extends Fragment {
private static int pageIndex;
private static final String TAG = "TAG";
ScreenSlidePageFragment(int id) {
pageIndex = id;
Log.v(TAG, "Page Index is " + pageIndex); // this logs twice
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
int resID = -1;
switch(pageIndex) {
case 0:
resID = R.layout.tutorial_page1;
break;
case 1:
resID = R.layout.tutorial_page2;
break;
case 2:
resID = R.layout.tutorial_page3;
break;
default:
resID = R.layout.tutorial_page1;
break;
}
Log.v(TAG, "Res Index is " + resID); // this logs twice
ViewGroup rootView = (ViewGroup) inflater.inflate(resID, container, false);
return rootView;
}
}
Run Code Online (Sandbox Code Playgroud)
日志是
构造函数 getItem 0 页索引为 0 getItem 1 页索引为 1 Res 索引为 2130903043 Res 索引为 2130903043
所以基本上它立即跳转到第二页,无论我是否使用 setCurrentItem() 设置了位置......
我认为我可能会通过尝试只有一个 Fragment 类而不是每个匹配布局的单独一个来作弊,但是......这应该有效吗?
请注意,我看到一个(我认为)相关的问题,因为第二个(初始)页面显示了两次 - 最初一次,然后再次滑动到下一页(应该是第 3 页?)。一旦我导航到第 3 页(两次滑动后),我就可以一直返回到第 1 页(应该是初始页面)。
想法?我究竟做错了什么 ?
所以,我解决了我自己的(根本)问题(尽管不是我遇到的奇怪的索引情况)。
我对 ViewPager 中每个页面的各个内容的实例化的误解是,会反复使用一个 Fragment,并且我会将参数传递给它的构造函数,以便告诉它要膨胀哪个布局。
相反,我意识到我应该拥有完全独立的 Fragment 类,每个类都拥有自己独特的布局,并且我可以使用 FragmentStatePagerAdapter 中 getItem() 中的相同位置 id 来实例化正确的 Fragment...现在对我来说很有意义。
参见下面的代码:
public class TutorialScreen extends FragmentActivity {
private static final int NUM_PAGES = 3;
private ViewPager pager;
private PagerAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.tutorial_layout);
// Instantiate Pager & Adapter
pager = (ViewPager) findViewById(R.id.pager);
adapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());
pager.setAdapter(adapter);
}
@Override
public void onBackPressed() {
if(pager.getCurrentItem() == 0) {
super.onBackPressed();
}
else {
pager.setCurrentItem(pager.getCurrentItem() -1);
}
}
// PagerAdapter SubClass
private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
public ScreenSlidePagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
Fragment fragment;
switch(position) {
case 0:
fragment = new TutorialPage1();
break;
case 1:
fragment = new TutorialPage2();
break;
case 2:
fragment = new TutorialPage3();
break;
default:
fragment = new TutorialPage1();
break;
}
return fragment;
}
@Override
public int getItemPosition(Object object) {
return POSITION_NONE;
}
@Override
public int getCount() {
return NUM_PAGES;
}
} /* EOC */
} /* EOC */
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8315 次 |
| 最近记录: |