导航栏隐藏的NestedScrollView底部[Android]

时间:2017-03-02 16:32:03

标签: android android-collapsingtoolbarlayout android-nestedscrollview

我在使用NestedScrollView的布局上遇到CollapsingToolbarLayout问题。当我将文本滚动到底部时,导航栏会覆盖最后一句。

enter image description here
layout.xml:

 <?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:fitsSystemWindows="true">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appBar"
        android:layout_width="match_parent"
        android:layout_height="250dp"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleTextAppearance="@style/ExpandedAppBar"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            app:title="Title">

            <ImageView
                android:id="@+id/toolbar_image_view"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:scaleType="centerCrop"
                android:src="@drawable/visit_at_office"
                app:layout_collapseMode="parallax" />

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:layout_collapseMode="pin" />

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

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

    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <TextView
            android:id="@+id/textView"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="@string/lorem_ipsum" />
    </android.support.v4.widget.NestedScrollView>
    </android.support.design.widget.CoordinatorLayout>

为TextView添加保证金底部修复了这个错误,但我想知道任何更好的解决方案,为什么会发生这种情况。有人可以帮帮我吗?

2 个答案:

答案 0 :(得分:1)

如果有人仍在寻找此问题的解决方案:

问题的原因在于CoordinatorLayout不能正确计算CollapsingToolbarLayout的大小,因为它具有设置为app:layout_collapseMode="pin"的工具栏。它认为CollapsingToolbarLayout将折叠到零高度,以便将所有可用空间留给NestedScrollView,但实际上发生的是工具栏保持固定状态,因此NestedScrollView向下移动到NavigationBar后面。

解决此问题的最简单方法是将android:minHeight="?attr/actionBarSize"(或您使用的任何工具栏高度)添加到CollapsingToolbarLayout中。这样,CoordinatorLayout就能正确知道NestedScrollView需要保留多少空间。

答案 1 :(得分:0)

您已在根布局中添加了android:fitsSystemWindows="true",例如CoordinatorLayout

此行将使视图适合全屏。