Android工具栏标签导航

时间:2015-11-02 08:45:16

标签: android toolbar android-tabs android-toolbar

如何在操作栏中添加标签(与设置按钮位于同一行的标签)?

Google's DeskClock Implementation

我相信他们甚至在marshmallow发布分支上使用已弃用的方法来实现这一目标:

mActionBar.setDisplayOptions(0);
mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);

他们的风格是:

<style name="DeskClock" parent="@style/BaseActivityTheme">
        <item name="android:windowActionBarOverlay">true</item>
        <item name="android:windowBackground">@color/default_background</item>
        <!-- Attributes from support.v7.appcompat -->
        <item name="actionBarStyle">@style/DeskClockActionBarStyle</item>
        <item name="actionBarTabStyle">@style/DeskClockTabStyle</item>
        <item name="actionBarTabBarStyle">@style/DeskClockTabBarStyle</item>
    </style>
    <style name="DeskClockTabBaseStyle" parent="Widget.AppCompat.ActionBar.TabView">
        <item name="android:paddingLeft">@dimen/actionbar_tab_padding</item>
        <item name="android:paddingRight">@dimen/actionbar_tab_padding</item>
        <item name="android:gravity">center</item>
    </style>
    <style name="DeskClockTabStyle" parent="DeskClockTabBaseStyle">
        <item name="android:background">?attr/selectableItemBackgroundBorderless</item>
    </style>
    <style name="DeskClockTabBarStyle" parent="Widget.AppCompat.ActionBar.TabBar">
        <item name="android:dividerPadding">12dp</item>
        <item name="android:gravity">center</item>
        <!-- Attributes from support.v7.appcompat -->
        <item name="showDividers">none</item>
    </style>
    <style name="DeskClockActionBarStyle" parent="Widget.AppCompat.ActionBar">
        <item name="android:background">@null</item>
        <item name="android:backgroundStacked">@null</item>
        <item name="android:backgroundSplit">@null</item>
        <!--suppress CheckTagEmptyBody Empty displayOptions to hide app title at launch. -->
        <item name="displayOptions"></item>
    </style>

修改

我仍然没有达到同样的效果。

My attempt looks like

风格:

<style name="Theme" parent="@style/AppTheme">
        <item name="android:windowActionBarOverlay">true</item>

        <!-- Attributes from support.v7.appcompat -->
        <item name="actionBarStyle">@style/DeskClockActionBarStyle</item>
        <item name="actionBarTabStyle">@style/DeskClockTabStyle</item>
        <item name="actionBarTabBarStyle">@style/DeskClockTabBarStyle</item>
    </style>

    <style name="DeskClockTabBaseStyle" parent="Widget.AppCompat.ActionBar.TabView">
        <item name="android:paddingLeft">@dimen/actionbar_tab_padding</item>
        <item name="android:paddingRight">@dimen/actionbar_tab_padding</item>
        <item name="android:gravity">center</item>
    </style>

    <style name="DeskClockTabStyle" parent="DeskClockTabBaseStyle">
        <item name="android:background">?attr/selectableItemBackgroundBorderless</item>
    </style>

    <style name="DeskClockTabBarStyle" parent="Widget.AppCompat.ActionBar.TabBar">
        <item name="android:dividerPadding">12dp</item>
        <item name="android:gravity">center</item>
        <!-- Attributes from support.v7.appcompat -->
        <item name="showDividers">none</item>
    </style>

    <style name="DeskClockActionBarStyle" parent="Widget.AppCompat.ActionBar">
        <item name="android:background">@null</item>
        <item name="android:backgroundStacked">@null</item>
        <item name="android:backgroundSplit">@null</item>
        <!--suppress CheckTagEmptyBody Empty displayOptions to hide app title at launch. -->
        <item name="displayOptions"></item>
    </style>

MainActivity:

    ActionBar mActionBar = getSupportActionBar();
    mActionBar.setDisplayOptions(0);
    mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);

    // Add 3 tabs, specifying the tab's text and TabListener
    for (int i = 0; i < NUM_PAGES; i++) {
        mActionBar.addTab(
                mActionBar.newTab()
                        .setText("Tab " + (i + 1))
                        .setTabListener(tabListener));
    }

2 个答案:

答案 0 :(得分:1)

如果适合你:

您可以使用PagerSlidingStrip

删除默认的actionBar并自定义您的slidingtabstrip到您的内容,并从XML添加设置按钮并在打开时膨胀菜单。

我相信这是可以实现的,尽管在这种情况下我从未使用它。

答案 1 :(得分:0)

要在工具栏上创建内嵌选项卡,您必须为其创建自定义视图。

actionbar_layout.xml(特别注意android:layout_gravity =“fill_horizo​​ntal”)

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    style="?attr/actionButtonStyle"
    android:layout_width="fill_parent"
    android:layout_height="match_parent"
    android:layout_gravity="fill_horizontal">

    <android.support.design.widget.TabLayout
        android:id="@+id/tab_layout_main"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

</RelativeLayout>

然后在您的活动中

 actionBar.setDisplayShowCustomEnabled(true);
 actionBar.setDisplayShowTitleEnabled(false);