0

我已经ActionBar 使用标签适配器实现了带有导航标签的 Sherlock。下面是我的标签适配器类:

 public static class TabsAdapter extends FragmentPagerAdapter implements
        ActionBar.TabListener, ViewPager.OnPageChangeListener
{
    private final Context mContext;
    private final ActionBar mActionBar;
    private final ViewPager mViewPager;
    private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>();

    static final class TabInfo
    {
        private final Class<?> clss;
        private final Bundle args;

        TabInfo(Class<?> _class, Bundle _args)
        {
            clss = _class;
            args = _args;
        }
    }

    public TabsAdapter(SherlockFragmentActivity activity, ViewPager pager)
    {
        super(activity.getSupportFragmentManager());
        mContext = activity;
        mActionBar = activity.getSupportActionBar();
        mViewPager = pager;
        mViewPager.setAdapter(this);
        mViewPager.setOnPageChangeListener(this);
    }

    public void addTab(ActionBar.Tab tab, Class<?> clss, Bundle args)
    {
        TabInfo info = new TabInfo(clss, args);
        tab.setTag(info);
        tab.setTabListener(this);
        mTabs.add(info);
        mActionBar.addTab(tab);
        notifyDataSetChanged();
    }

    @Override
    public int getCount()
    {
        return mTabs.size();
    }

    @Override
    public Fragment getItem(int position)
    {
        TabInfo info = mTabs.get(position);
        return Fragment.instantiate(mContext,info.clss.getName(),
                info.args);

    }

    public void onPageScrolled(int position, float positionOffset,
            int positionOffsetPixels)
    {
    }

    public void onPageSelected(int position)
    {
        mActionBar.setSelectedNavigationItem(position);
    }

    public void onPageScrollStateChanged(int state)
    {
    }

    public void onTabSelected(Tab tab, FragmentTransaction ft)
    {
        Object tag = tab.getTag();
        for (int i = 0; i < mTabs.size(); i++)
        {
            if (mTabs.get(i) == tag)
            {
                mViewPager.setCurrentItem(i);
            }
        }
    }
    public void onTabUnselected(Tab tab, FragmentTransaction ft)
    {
    }

    public void onTabReselected(Tab tab, FragmentTransaction ft)
    {
    }
}

我的问题是如何使用addToBackStack()Fragment.instantiate()(或者如果有任何其他方式来处理后退按钮)?

4

1 回答 1

1

我的问题是如何使用 addtobackstack 和 Fragment.instantiate 或任何其他方式来处理后退按钮

你真的不应该这样做。如果您要在 a 中使用带有片段的选项卡,ViewPager可以安全地假设用户在使用应用程序时可以切换/滑动很多选项卡片段。当他想退出活动时,让 BACK 按钮重新创建他的步骤可能非常令人沮丧(想象一下在切换标签 15-20 次后试图退出此活动)。

如果你真的想这样做,那么将用户的导航路径存储在一个整数列表/数组中(当滑动/切换选项卡时,存储ViewPager用户所在页面的 int 位置)。然后覆盖onBackPressed活动的方法并让它弹出(每次单击 BACK 按钮时)从前一个列表/数组移动ViewPager到该位置的最后一个位置(同时突出显示正确的选项卡)。

于 2013-02-16T10:25:18.680 回答