FAB隐藏在Bottom Sheet下

时间:2016-06-01 15:47:55

标签: android floating-action-button bottom-sheet

我有以下XML:

<android.support.design.widget.CoordinatorLayout
    android:id="@+id/sliding_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_below="@id/app_bar">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <fragment
            android:id="@+id/fragment1"
            android:name="com.xyz.Fragment1"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            tools:layout="@layout/fragment_layout1" />
    </LinearLayout>

    <LinearLayout
        android:id="@+id/layoutBottomSheet"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:elevation="@dimen/global_margin"
        android:orientation="vertical"
        app:layout_behavior="@string/bottom_sheet_behavior">

        <fragment
            android:id="@+id/fragment2"
            android:name="com.xyz.Fragment2"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center|top"
            tools:layout="@layout/fragment_layout2" />
    </LinearLayout>

    <android.support.design.widget.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginEnd="@dimen/global_margin"
        android:layout_marginRight="@dimen/global_margin"
        android:src="@drawable/ic_add_white_24dp"
        app:borderWidth="0dp"
        app:elevation="4dp"
        app:layout_anchor="@id/layoutBottomSheet"
        app:layout_anchorGravity="top|right|end" />
</android.support.design.widget.CoordinatorLayout>

布局应显示为Fragment1,然后显示为Fragment2,FAB固定在Fragment2,但高于 Fragment2,而不是之下。

实际上它显示为,

screenshot

出了什么问题?有什么想法吗?

3 个答案:

答案 0 :(得分:2)

您的Java _ - A . - LinearLayout的海拔高度为layoutBottomSheet。如果此维度大于您定义为FloatingActionButton的高程的4dp,则该按钮隐藏在较高布局后面。

可能该尺寸大于4dp。因此,相应地改变按钮的高度。

答案 1 :(得分:0)

您可以在FAB上调用s_addr,其值高于底部工作表标高(如果您使用的是setCompatElevation(...),则为16dp),以确保它位于顶部。

答案 2 :(得分:0)

我在FloatingActionBButton中添加了app:layout_dodgeInsetEdges =“ bottom”,并在视图中添加了app:layout_insetEdge =“ bottom”,并具有最下面的行为:

    <android.support.design.widget.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end|bottom"
        android:layout_margin="16dp"
        android:clickable="true"
        android:focusable="true"
        app:backgroundTint="@color/white"
        app:fabSize="normal"
        app:layout_dodgeInsetEdges="bottom"
        app:srcCompat="@drawable/icon"
        />

    <View
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_insetEdge="bottom"
        app:layout_behavior="android.support.design.widget.BottomSheetBehavior"
        />