浮动操作按钮未显示在顶部

Mat*_*rdt 1 xml android android-layout floating-action-button recyclerview-layout

我正在尝试创建一个浮动操作按钮,但由于某种原因,它会一直在我的recylerView下渲染按钮.我试过搞乱布局顺序,高程,我甚至尝试.bringToFront()在java代码中使用该方法.

在此输入图像描述

Activity_main

<android.support.v4.widget.DrawerLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/drawer"
    android:layout_width="match_parent" android:fitsSystemWindows="true"
    android:layout_height="match_parent">

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

        <include android:id="@+id/toolbar_actionbar"
            layout="@layout/toolbar_default"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

        <include
            android:id="@+id/fab_layout"
            layout="@layout/fab_layout"
            android:layout_width="@dimen/fab_button_diameter"
            android:layout_height="@dimen/fab_button_diameter"
            android:layout_alignParentBottom="true"
            android:layout_alignParentRight="true"
            android:layout_alignParentEnd="true" />

        <FrameLayout android:id="@+id/container"
           android:layout_width="match_parent"
           android:clickable="true" android:layout_height="match_parent"
           android:layout_below="@+id/toolbar_actionbar">

        <android.support.v7.widget.RecyclerView
           android:id="@+id/cardList"
           android:layout_width="match_parent"
           android:layout_height="match_parent" />

    </FrameLayout>

</RelativeLayout>

<!-- android:layout_marginTop="?android:attr/actionBarSize"-->
<com.android.expresso.expresso.ScrimInsetsFrameLayout android:id="@+id/scrimInsetsFrameLayout"
    android:layout_width="@dimen/navigation_drawer_width"
    android:layout_height="wrap_content"
    android:fitsSystemWindows="true"
    android:layout_gravity="start"
    app:insetForeground="#4000"
    android:elevation="10dp">
    <fragment android:id="@+id/fragment_drawer"
        android:name="com.android.expresso.expresso.NavigationDrawerFragment"
        android:layout_width="@dimen/navigation_drawer_width"
        android:layout_height="match_parent" android:fitsSystemWindows="true"
        app:layout="@layout/fragment_navigation_drawer" />
</com.android.expresso.expresso.ScrimInsetsFrameLayout>
Run Code Online (Sandbox Code Playgroud)

Fab_layout

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">

    <ImageButton
        android:id="@+id/fab_image_button"
        android:layout_width="@dimen/fab_button_diameter"
        android:layout_height="@dimen/fab_button_diameter"
        android:background="@drawable/fab_shape"
        android:src="@drawable/btn_order_hub"/>

</FrameLayout>
Run Code Online (Sandbox Code Playgroud)

sna*_*msm 7

fab_layout应该是xml中的最后一个视图.绘图是按照xml的顺序 - 您正在绘制FAB,在其他视图(容器)之后,它们正在覆盖FAB

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

    <include android:id="@+id/toolbar_actionbar"
        layout="@layout/toolbar_default"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <FrameLayout android:id="@+id/container"
       android:layout_width="match_parent"
       android:clickable="true" android:layout_height="match_parent"
       android:layout_below="@+id/toolbar_actionbar">

        <android.support.v7.widget.RecyclerView
           android:id="@+id/cardList"
           android:layout_width="match_parent"
           android:layout_height="match_parent" />

        <include
            android:id="@+id/fab_layout"
            layout="@layout/fab_layout"
            android:layout_width="@dimen/fab_button_diameter"
            android:layout_height="@dimen/fab_button_diameter"
            android:layout_alignParentBottom="true"
            android:layout_alignParentRight="true"
            android:layout_alignParentEnd="true" />

    </FrameLayout>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)

  • FAB也应具有高程,这将使其在相关设备上"在顶部". (2认同)