Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/179.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/svg/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 底部的元素使用AppBarLayout在导航栏后面绘制元素_Android_Android Layout_Android Fragments_Android Coordinatorlayout - Fatal编程技术网

Android 底部的元素使用AppBarLayout在导航栏后面绘制元素

Android 底部的元素使用AppBarLayout在导航栏后面绘制元素,android,android-layout,android-fragments,android-coordinatorlayout,Android,Android Layout,Android Fragments,Android Coordinatorlayout,我正在尝试使用不同屏幕上的片段进行导航。 我们决定滚动时工具栏必须关闭。这很容易使用AppBarLayout和layout_scrollFlags“scroll” 因此,我使用一个嵌套的ScrollView来包含片段。 有些片段只包含一个按钮,我希望它被放置在底部。其他的是需要滚动的大菜单 为此,我使用NestedScrollView上的flag fillViewPort。如果碎片很短,它将填充屏幕,按钮将出现在底部 问题是,如果我在AppBarLayout上使用标志“scroll”,如果片段底

我正在尝试使用不同屏幕上的片段进行导航。 我们决定滚动时工具栏必须关闭。这很容易使用AppBarLayout和layout_scrollFlags“scroll”

因此,我使用一个嵌套的ScrollView来包含片段。 有些片段只包含一个按钮,我希望它被放置在底部。其他的是需要滚动的大菜单

为此,我使用NestedScrollView上的flag fillViewPort。如果碎片很短,它将填充屏幕,按钮将出现在底部

问题是,如果我在AppBarLayout上使用标志“scroll”,如果片段底部有一个按钮,它会被放置在导航栏后面,而如果我不使用标志“scroll”NestedScrollView则会调整其大小并显示按钮

该测试很容易在AndroidStudio上的布局预览中重现

我想做些奇怪的事吗?如何使用带有“滚动”标志的Coordinator和AppBarLayout在底部为某些(小)片段设置一个按钮? 请注意,fitsSystemWindow对此没有影响

这只是而不是
app:layout\u scrollFlags=“scroll”

这是使用
app:layout\u scrollFlags=“scroll”

这是简化布局的代码:

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:context=".MainActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        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:layout_scrollFlags="scroll"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

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

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

        <include layout="@layout/content_main" />

    </android.support.v4.widget.NestedScrollView>

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

另外,以防万一,这是“content_main.xml”


解决方案:
AppBarLayout
下方单独添加一个
将避免屏幕的可见性,因为它会占据屏幕的宽度和高度,但默认情况下,
CoordinatorLayout
将一个视图移到另一个视图的下方

因此,解决方法是将
包装在单独的布局中,如
所示:

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        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:layout_scrollFlags="scroll"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

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

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

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

            <include layout="@layout/content_main" />

        </android.support.v4.widget.NestedScrollView>

    </LinearLayout>

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

这将按预期工作,您将能够看到视图,并隐藏滚动上的工具栏


代码的其余部分保持不变。尝试一下,如果有任何问题,请发表评论。

是!这就成功了。我看到的唯一问题是,即使底部有按钮,屏幕仍然可以滚动,滚动时工具栏消失,而实际上没有什么可滚动的。但在任何情况下,这都是更好和更有用的。谢谢
<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        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:layout_scrollFlags="scroll"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

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

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

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

            <include layout="@layout/content_main" />

        </android.support.v4.widget.NestedScrollView>

    </LinearLayout>

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