将Tablayout对齐到AppbarLayout的底部

时间:2016-01-28 18:35:36

标签: android android-appbarlayout

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="160dp"
    android:theme="@style/AppTheme.AppBarOverlay">
    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="?attr/colorPrimary"
        app:popupTheme="@style/AppTheme.PopupOverlay"/>
    <android.support.design.widget.TabLayout
        android:id="@+id/sliding_tabs"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabMode="scrollable"/>
</android.support.design.widget.AppBarLayout>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:app="http://schemas.android.com/apk/res-auto"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
              android:orientation="vertical">
    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="0px"
        android:layout_weight="1"
        android:background="@android:color/white"/>
</LinearLayout>

然而,以下是屏幕上显示的布局。我无法将标签对齐到AppbarLayout的底部。有没有办法让它们与底部对齐?

enter image description here

2 个答案:

答案 0 :(得分:0)

如果你看到Android文档,AppBarLayout是LinearLayout的孩子。因此,您应该能够像使用LinearLayout一样强制子视图到底部 - 使用权重。您只需添加一个Space小部件即可获取工具栏和TabLayout之间的剩余空间并为其提供所需的权重(您可能需要进行一些试验和错误才能获得精确的权重值)。

答案 1 :(得分:0)

您只需将TabLayout放在LinearLayout高度为match_parent并将gravity设置为bottom的范围内即可。像这样的东西

<LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="bottom">
<android.support.design.widget.TabLayout
        android:id="@+id/sliding_tabs"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabMode="scrollable"/>
</LinearLayout

希望这会奏效。