Android 折叠工具栏时隐藏浮动按钮

Android 折叠工具栏时隐藏浮动按钮,android,android-design-library,android-collapsingtoolbarlayout,Android,Android Design Library,Android Collapsingtoolbarlayout,我有一个协调器布局,包含一个折叠工具栏、一个嵌套滚动视图和一个浮动按钮。 我的浮动按钮位于折叠工具栏的右下角我希望在折叠工具栏完全折叠时按钮消失。并在其他情况下可见 我的xml: <?xml version="1.0" encoding="utf-8"?> <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"

我有一个协调器布局,包含一个折叠工具栏、一个嵌套滚动视图和一个浮动按钮。 我的浮动按钮位于折叠工具栏的右下角我希望在折叠工具栏完全折叠时按钮消失。并在其他情况下可见

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

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay"
        android:id="@+id/appBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapse_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleMarginStart="48dp"
            app:expandedTitleMarginEnd="64dp">

            <ImageView
                android:id="@+id/collapsing_image"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:fitsSystemWindows="true"
                app:layout_collapseMode="parallax"
                android:scaleType="centerCrop"
                android:src="@drawable/welcome"/>

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
                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="match_parent"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_gravity="fill_vertical"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto">

        <FrameLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/content_frame">

        </FrameLayout>

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

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="-60dp"
        android:layout_marginRight="16dp"
        android:src="@android:drawable/ic_dialog_email"
        app:layout_anchor="@id/collapse_toolbar"
        app:layout_anchorGravity="bottom|right|end" />

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

有可能吗?怎样做?

试试这个小变化

<android.support.design.widget.FloatingActionButton
    ...
    app:layout_anchor="@id/appBar"
    app:layout_anchorGravity="bottom|right|end" />

将offset listener设置为工具栏将为您提供更大的灵活性:您可以决定当工具栏折叠/打开时会发生什么

    appBarLayout.addOnOffsetChangedListener(
    AppBarLayout.OnOffsetChangedListener { appBarLayout, verticalOffset ->
    if (verticalOffset == 0) {
        showFAB()
        // logic when toolbar is open (for example show fab)
     } else {
        hideFAB()
        // logic when toolbar has collapsed (for example hide fab)
     })
如果您想知道工具栏何时处于中间位置/您需要java代码:

谢谢,太好了!但是你能告诉我如何在java中检查这种折叠状态,以便在它折叠时可以更改锚点状态吗?你从这里尝试过解决方案吗?谢谢,我尝试将其放入java onCreate:appBar.addOnOffsetChangedListener(新的AppBarLayout.OnOffsetChangedListener()中但是我在这行上得到了一个nullpointerexception可能您忘记了用
findViewById()
或您在
onOffsetChanged()
方法中引用的另一个视图初始化
appBar
视图,如果FloatingActionButton位于一个布局(xml)中,该怎么办文件,如果是片段,AppBar是否位于不同布局的文件上?