Android 底部的元素使用AppBarLayout在导航栏后面绘制元素
我正在尝试使用不同屏幕上的片段进行导航。 我们决定滚动时工具栏必须关闭。这很容易使用AppBarLayout和layout_scrollFlags“scroll” 因此,我使用一个嵌套的ScrollView来包含片段。 有些片段只包含一个按钮,我希望它被放置在底部。其他的是需要滚动的大菜单 为此,我使用NestedScrollView上的flag fillViewPort。如果碎片很短,它将填充屏幕,按钮将出现在底部 问题是,如果我在AppBarLayout上使用标志“scroll”,如果片段底部有一个按钮,它会被放置在导航栏后面,而如果我不使用标志“scroll”NestedScrollView则会调整其大小并显示按钮 该测试很容易在AndroidStudio上的布局预览中重现 我想做些奇怪的事吗?如何使用带有“滚动”标志的Coordinator和AppBarLayout在底部为某些(小)片段设置一个按钮? 请注意,fitsSystemWindow对此没有影响 这只是而不是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”,如果片段底
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>