ViewPager扩展到屏幕底部

时间:2016-04-10 12:01:41

标签: android listview android-fragments android-viewpager

我是Android开发的新手,我面临以下问题。 这是我主要活动的布局:

<?xml version="1.0" encoding="utf-8"?>

<android.support.design.widget.CoordinatorLayout
    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.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar_main"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:elevation="4dp"
            app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
            app:layout_scrollFlags="scroll|enterAlways">

            <android.support.design.widget.TabLayout
                android:id="@+id/tabs"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                app:tabIndicatorColor="@color/white"
                app:tabTextColor="@color/selected_text"
                app:tabSelectedTextColor="@color/white"/>

        </android.support.v7.widget.Toolbar>

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/main_pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

</android.support.design.widget.CoordinatorLayout>

对于ViewPager中的每个标签,我都有一个片段,这是其中一个的布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:background="@color/colorPrimary"
    android:id="@+id/linear_layout"
    tools:context=".fragments.Reviews">

    <RatingBar
        android:id="@+id/review_totalRating"
        style="?android:attr/ratingBarStyle"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:numStars="5"
        android:stepSize=".5"
        android:isIndicator="true"
        android:progressTint="@color/golden"
        android:layout_gravity="center"
        android:paddingTop="10dp"
        android:paddingBottom="5dp" />
    <ListView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:divider="@android:color/transparent"
        android:dividerHeight="8dp"
        android:paddingLeft="8dp"
        android:paddingRight="8dp"
        android:id="@+id/listView_reviews" />

</LinearLayout>

然后我用我的ListView填充其布局在另一个xml文件中定义的项目。我的问题在于ViewPager layout_height:它现在设置为match_parent,但元素在屏幕底部延伸,结果是ListView的最后一个元素被导航按钮覆盖。 这就是我在设计编辑器中看到的 ViewPager overflow

如何在导航按钮之前停止元素?

2 个答案:

答案 0 :(得分:5)

我也遇到过这个问题。这是因为AppBarLayout中的CoordinatorLayout行为。默认情况下,当您从模板创建项目时,它将设置隐藏Toolbar的布局。您可以运行您的示例并进行检查 - 只需向上滑动工具栏,它就会隐藏,ViewPager将向上移动然后正确地粘在屏幕底部。

对于某些情况,它不是解决方案,因此您可以通过从app:layout_scrollFlags删除Toolbar属性来停用此行为。在此之后,工具栏将变为不可隐藏,ViewPager将正确计算自己的身高。

答案 1 :(得分:1)

我解决了使用LinearLayout作为CoordinatorLayout的唯一子项,因此其他所有内容都成为LinearLayout的子项。在我看来,这只是一个简单的解决方法,而不是最终的解决方案,但现在它的工作原理。这是我主要活动的布局:

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
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">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

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

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar_main"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:elevation="4dp"
            app:layout_scrollFlags="scroll|enterAlways"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
            app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

            <android.support.design.widget.TabLayout
                android:id="@+id/tabs"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                app:tabIndicatorColor="@color/orange_050"
                app:tabSelectedTextColor="@color/orange_050"
                app:tabTextColor="@color/orange_050"/>

        </android.support.v7.widget.Toolbar>

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/main_pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

</LinearLayout>