如何在Android中的ActionBar下面始终显示ActionBar选项卡

时间:2014-02-18 09:09:38

标签: android tabs android-actionbar actionbarsherlock

我一直在寻找有关如何始终在ActionBar下方显示ActionBar标签的信息,即使手机朝向横向也是如此。我知道它会自动将标签放在ActionBar中,具体取决于屏幕上是否有足够的空间来容纳它们,但我希望它们始终固定在ActionBar下面,即使在横向上也是如此。我发现了一个类似的问题没有明确答案:How to display tabs below action bar。我也知道很多谷歌应用程序,如; Google Play,Google Music等实现了这种类型的设计模式,因此它显然是可以实现的,并且可以作为设计模式使用。

我目前正在使用ActionBarSherlock库来创建我的滑动标签导航,如果有人自己想出如何做到这一点,我会非常感激。提前谢谢。

这是我的活动代码:

@Override
protected void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);

    viewPager = new ViewPager(this);
    viewPager.setId(R.id.pager);
    setContentView(viewPager);

    tabsAdapter = new TabsAdapter(this, viewPager); // Declares the tabs adapter class with the view pager view

    actionBarTabs = getSupportActionBar();
    actionBarTabs.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
    actionBarTabs.setCustomView(spinnerView);
    actionBarTabs.setDisplayShowCustomEnabled(true);    

    /* Adds fragments to the tabs adapter */
    tabsAdapter.addTab(actionBarTabs.newTab().setText("FRAG1"), Fragment_1.class, null);
    tabsAdapter.addTab(actionBarTabs.newTab().setText("FRAG2"), Fragment_2.class, null);
    tabsAdapter.addTab(actionBarTabs.newTab().setText("FRAG3"), Fragment_3.class, null);
}

这是我的TabsAdapter代码:

public class TabsAdapter extends FragmentPagerAdapter implements ActionBar.TabListener , ViewPager.OnPageChangeListener 
{
private final Context context;
private final ActionBar actionBar;
private final ViewPager viewPager;
private final ArrayList<TabInfo> tabsList = new ArrayList<TabInfo>();

/**
 * TabInfo class
 * 
 * Static class containing the tab information.
 * 
 * @since 1.0
 */
static final class TabInfo
{
    private final Class<?> clss;
    private final Bundle args;

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

/**
 * Tabs adapter overload constructor.
 * 
 * @param fragmentActivity sets the fragment activity to the adapter.
 * @param refViewPager sets the viewPager variable.
 * @see
 * @since 1.0
 */
public TabsAdapter(SherlockFragmentActivity fragmentActivity, ViewPager refViewPager) 
{
    super(fragmentActivity.getSupportFragmentManager());
    context = fragmentActivity;
    actionBar = fragmentActivity.getSupportActionBar();
    viewPager = refViewPager;
    viewPager.setAdapter(this);
    viewPager.setOnPageChangeListener(this);
}

/**
 * Add tab method to add a tab to the list.
 * 
 * @param tab sets the tab to be added to the tabs in the action bar.
 * @param clss sets the class variable in the TabInfo class.
 * @param args sets the bundle variable in the TabInfo class.
 * @see
 * @since 1.0
 */
public void addTab(ActionBar.Tab tab, Class<?> clss, Bundle args)
{
    TabInfo info = new TabInfo(clss, args);
    tab.setTag(info);
    tab.setTabListener(this);
    tabsList.add(info);
    actionBar.addTab(tab);
    notifyDataSetChanged();
}

@Override
public void onPageScrollStateChanged(int state) 
{

}

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

}

@Override
public void onPageSelected(int position) 
{
    actionBar.setSelectedNavigationItem(position);
}

@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) 
{
    viewPager.setCurrentItem(tab.getPosition());
    Object tag = tab.getTag();
    for (int i = 0; i<tabsList.size(); i++)
    {
        if (tabsList.get(i) == tag)
        {
            viewPager.setCurrentItem(i);
        }
    }

}

@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) 
{

}

@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) 
{

}

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

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

3 个答案:

答案 0 :(得分:12)

我在横向模式下遇到了同样的问题,我在这里找到了解决方案:http://andreimihu.com/blog/2013/10/17/android-always-embed-tabs-in-actionbar/

基本上,当你和我想在外面时,作者想要操纵栏内的标签。所以,只需将方法调用更改为false(来自上述链接的代码,但稍作修改):

// This is where the magic happens!
public void forceTabs() {
    try {
        final ActionBar actionBar = getActionBar();
        final Method setHasEmbeddedTabsMethod = actionBar.getClass()
            .getDeclaredMethod("setHasEmbeddedTabs", boolean.class);
        setHasEmbeddedTabsMethod.setAccessible(true);
        setHasEmbeddedTabsMethod.invoke(actionBar, false);
    }
    catch(final Exception e) {
        // Handle issues as needed: log, warn user, fallback etc
        // This error is safe to ignore, standard tabs will appear.
    }
}

答案 1 :(得分:3)

首先,您所描述的“许多Google应用程序,例如; Google Play,Google Music等实现此类设计模式”并不一定是与ActionBar相关的导航标签。

有很多实现使用带有标题指示符的viewPager。请参阅PagerSlidingTabStrip库以获得良好的实施。

另外,你应该查看官方的android文档,它会深入讨论有关使用标签的导航,并显示获取它的不同方法。请查看文档中的这些页面:Providing Descendant and Lateral NavigationCreating Swipe Views with Tabs

此外, stackoverflow.com 上有很多关于此主题的答案。我在这个答案中已经提到了我建议的图书馆:https://stackoverflow.com/a/16544501/529138

检查此问题以及相关答案:Tabs below action bar

这些资源足以帮助您获得所需的功能:)

答案 2 :(得分:1)

actionBar.setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM | ActionBar.DISPLAY_SHOW_HOME);

actionBar.setLogo(空);

    View homeIcon = findViewById(
            Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB ? 
                    android.R.id.home : android.support.v7.appcompat.R.id.home);
    ((View) homeIcon.getParent()).setVisibility(View.GONE);
    ((View) homeIcon).setVisibility(View.GONE);