2015-06-10 25 views
29

Desidero allineare in basso a destra il mio FAB.Bottom di allineamento inferiore Pulsante di azione

  1. ho provato con android:gravity="bottom|right"
  2. Quando provo android:layout_alignParentBottom="true "FAB scompare
  3. Quando provo android:layout_alignBottom="@id/lista_tiendas"FAB scompare

Non sembra complicato, ma non riesco proprio a realizzarlo

Qualsiasi idea?

<?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> 

risposta

77

Per RelativeLayout:

<android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    android:layout_alignParentBottom="true" 
    android:layout_alignParentRight="true" 
    ... /> 

Per CoordinatorLayout, è necessario utilizzare android:layout_gravity="end|bottom"


Per ConstraintLayout:

<android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    app:layout_constraintBottom_toBottomOf="parent" 
    app:layout_constraintEnd_toEndOf="parent" 
    ... /> 

Vedere this answer per ulteriori informazioni.

+1

sì, ho corretto il formato del codice così appare RelativeLayout! Tx –

+0

Questo ha funzionato anche per me, grazie! Perché LinearLayout non funziona per un FAB? – Michael

+1

Consigliato è: android: layout_alignParentEnd = "true" – Zon

1

sono stato in grado di ottenere il codice per lavorare in questo modo:

<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"/> 

Tuttavia, non ha funzionato con la belowTextView invece che sopra, credo che potrebbe essere un bug.

+0

Ok, ma non ho una vista testuale, ho una listview che prende tutto lo schermo, quindi se lo metto sopra, non avrò la posizione desiderata! –

5

Sembra che FloatingActionButton non sia posizionato correttamente all'interno di RelativeLayout.

Ho modificato RelativeLayout su FrameLayout e il problema è stato risolto! Spero che aiuti!

<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> 
9

layout dovrebbe essere RelativeLayout. Provate il codice seguente:

<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> 

+0

Avvolgere il pulsante mobile in un layout lineare è stato il trucco per me. Altrimenti ignorerebbe i margini. –

0

Prova

android: layout_gravity = "bottom | right"

2

Prova utilizzando android.support.design.widget.CoordinatorLayout e android:layout_gravity="bottom|right" lavori per me.

Problemi correlati