6

我正在创建具有三个视图的 ViewPager。在第一个视图上是一个 ListView,其中 onItemClick 用其中的 WebView 替换了该片段新片段。我有两个问题:当添加“transaction.addToBackStack(null)”或“transaction.setCustomAnimations(...)”片段时,WebView 会停止显示。如果没有这些行,它会显示,但我不能按 BACK 按钮返回列表。

我正在根据该教程这个 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;
}

以及来自该列表片段的 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 );
                }
            }
        }
    } );
4

2 回答 2

2

查看我对上述问题的新答案:https ://stackoverflow.com/a/11974777/685292

您可以在此处看到一个示例,因为addToBackStack(null)不适用于ViewPager片段,因此您可以自己使用ViewPager实现简单的反向堆叠。另请注意,关于您的问题的主要问题可能是缺少getItemId(int position)覆盖方法。

于 2012-08-15T18:29:28.323 回答
1

在新的设计支持库中,我使用此解决方案
您可以使用堆栈通过推送堆栈中的位置并使用堆栈中的弹出返回来存储选项卡。

在 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 活动中,

@Override
public void onBackPressed() {
    if (stackkk.size() > 1) {
        stackkk.pop();
        mPager.setCurrentItem(stackkk.lastElement());
    } else {
//do wat you want
    }
}

希望这可能会有所帮助

于 2015-10-09T01:37:13.780 回答