底部对齐浮动操作按钮

时间:2015-06-10 23:32:02

标签: android floating-action-button

我想在我的FAB右下方对齐。

  1. 我尝试使用android:gravity="bottom|right"
  2. 当我尝试android:layout_alignParentBottom="true时,“FAB消失
  3. 当我尝试android:layout_alignBottom="@id/lista_tiendas" FAB消失时
  4. 这似乎并不复杂,但我无法完成它

    任何想法?

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    
    <ListView
        android:id="@+id/lista_tiendas"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="5dp"
        android:divider="@android:color/transparent"
        android:dividerHeight="4.0sp"/>
    
    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_add_white_48dp"
        app:backgroundTint="@color/spg_rosa"
        app:borderWidth="0dp"
        app:elevation="8dp"
        app:fabSize="normal"
        android:layout_alignParentRight="true"
        android:layout_alignParentBottom="@id/lista_tiendas"
         />
    </RelativeLayout>
    

7 个答案:

答案 0 :(得分:123)

getB

RelativeLayout

对于<android.support.design.widget.FloatingActionButton android:id="@+id/fab" android:layout_alignParentBottom="true" android:layout_alignParentRight="true" ... /> ,您应该使用CoordinatorLayout

android:layout_gravity="end|bottom"

ConstraintLayout

有关详细信息,请参阅this answer

答案 1 :(得分:11)

布局应为 RelativeLayout 。尝试下一个代码:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">

<LinearLayout
    android:id="@+id/ly_list_form"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical">


    <ListView
        android:id="@+id/list_forms"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:dividerHeight="1dp" />

</LinearLayout>

<LinearLayout
    android:id="@+id/ly_bar_bottom"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:gravity="right"
    android:orientation="horizontal">

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/button_addc"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|end"
        android:layout_margin="28dp"
        android:src="@drawable/ic_add"
        app:borderWidth="0dp"
        app:elevation="6dp"
        app:pressedTranslationZ="12dp" />
</LinearLayout>

答案 2 :(得分:5)

看起来FloatingActionButton在RelativeLayout中没有正确定位。

我将RelativeLayout更改为FrameLayout,问题解决了! 希望它有所帮助!

    

<ListView
    android:id="@+id/mylist"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:divider="@android:color/transparent"
    android:dividerHeight="1.0sp" />

<android.support.design.widget.FloatingActionButton
    android:id="@+id/fab"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="right|bottom"
    android:src="@drawable/ic_add_white_48dp"
    app:backgroundTint="@color/spg_rosa"
    app:borderWidth="0dp"
    app:elevation="8dp"
    app:fabSize="normal" />

</FrameLayout>

答案 3 :(得分:2)

我能够通过这样做来获得代码:

<android.support.design.widget.FloatingActionButton
    android:id="@+id/fab"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    app:backgroundTint="#ff0000"
    app:borderWidth="0dp"
    app:elevation="8dp"
    app:fabSize="normal"
    android:layout_alignLeft="@+id/text"
    android:layout_above="@+id/text"/>

但是,它不能与below TextView而不是上述{{1}}一起使用,我相信这可能是一个错误。

答案 4 :(得分:2)

尝试使用android.support.design.widget.CoordinatorLayoutandroid:layout_gravity="bottom|right"为我工作。

答案 5 :(得分:0)

尝试

  

机器人:layout_gravity = “底部|右”

答案 6 :(得分:0)

在相对布局的底部和中心对齐按钮

将这两个添加到您的浮动操作按钮容器中

    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true"

输出将是: like this