我正在使用三个视图创建ViewPager。在第一个视图是ListView,其中onItemClick用其中的WebView替换该片段的新片段。我有两个问题:添加'transaction.addToBackStack(null)'或'transaction.setCustomAnimations(...)'片段与WebView停止显示。没有这些显示的行,但我不能按BACK按钮返回列表。
我正在根据that tutorial和this SO question创建代码。在那个问题中,使用了PagerAdapter,我正在使用FragmentPagerAdapter。此外,我不需要更换更多碎片。它只能是一次(从列表到webView并返回)。
这是我的适配器代码:
public Fragment getItem( int position )
{
Fragment fragment = null;
switch ( position )
{
case 0: // news
if ( mFragmentAtPos0 == null )
{
mFragmentAtPos0 = new NewsListFragment( new FirstPageFragmentListener()
{
@Override
public void onSwitchToNewsFragment( String url, ViewGroup container )
{
FragmentTransaction transaction = fm.beginTransaction();
transaction.setCustomAnimations( R.anim.rotate_in, R.anim.rotate_out, R.anim.rotate_in, R.anim.rotate_out );
WebViewFragment wv = new WebViewFragment( url, context );
transaction.replace( container.getId(), wv );
transaction.commit();
mFragmentAtPos0 = wv;
notifyDataSetChanged();
}
} );
}
fragment = mFragmentAtPos0;
break;
case 1:
fragment = new NewsInfoFragment( context, true );
break;
case 2:
fragment = new NewsInfoFragment( context, false );
break;
}
return fragment;
}
来自该List的片段的onCreateView()的和片段:
listView.setOnItemClickListener( new OnItemClickListener()
{
@Override
public void onItemClick( AdapterView<?> parent, View view, int position, long id )
{
if ( position < listNewsAdapter.getCount() - 1 )
{
if ( listener != null )
{
listener.onSwitchToNewsFragment( listNewsAdapter.getItem( position ).getNewsUrl(), container );
}
}
}
} );
答案 0 :(得分:2)
查看我对上述问题的新答案:https://stackoverflow.com/a/11974777/685292
您可以看到一个示例如何使用 ViewPager 实现简单的后备堆叠,因为 addToBackStack(null)不适用于 ViewPager 碎片。另请注意,您的问题的主要问题可能是缺少 getItemId(int position)覆盖方法。
答案 1 :(得分:0)
在新设计支持库中,我使用此解决方案
您可以使用堆栈来存储tabpositon,方法是在堆栈中按下位置并使用pop in stack回来。
在viewpager中有3个片段的主要活动中,我创建堆栈 和推送和弹出数据。
private Stack<Integer> stackkk;
private ViewPager mPager;
private int tabPosition = 0;
mTabLayout.setupWithViewPager(mPager);
mPager.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(mTabLayout));
mTabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
tabPosition = tab.getPosition();
mPager.setCurrentItem(tab.getPosition());
if (stackkk.empty())
stackkk.push(0);
if (stackkk.contains(tabPosition)) {
stackkk.remove(stackkk.indexOf(tabPosition));
stackkk.push(tabPosition);
} else {
stackkk.push(tabPosition);
}
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
tabPositionUnselected = tab.getPosition();
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
}
});
}
并且在onBackPressed in activity中,
@Override
public void onBackPressed() {
if (stackkk.size() > 1) {
stackkk.pop();
mPager.setCurrentItem(stackkk.lastElement());
} else {
//do wat you want
}
}
希望这可能会有所帮助