Centra un pulsante in un layout lineare


338

Sto usando un layout lineare per visualizzare una schermata iniziale piuttosto leggera. Ha 1 pulsante che dovrebbe centrare lo schermo sia in orizzontale che in verticale. Comunque, qualunque cosa provi a fare, il pulsante allinea il centro in alto. Ho incluso l'XML di seguito, qualcuno può indicarmi la giusta direzione?

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">

    <ImageButton android:id="@+id/btnFindMe" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical|center_horizontal"
        android:background="@drawable/findme"></ImageButton>

</LinearLayout>

6
Ciò che lo risolveva per me in un LinearLayout con allineamento orizzontale era impostare layout_widthsu "wrap_content". Successivamente hanno layout_gravityfatto quello che doveva fare!
Qualcuno da qualche parte il

Se devi assolutamente usare LinearLayout, penso che dovrebbe funzionare: stackoverflow.com/questions/18051472/…
Antonio,

Risposte:


374

Se si desidera centrare un elemento al centro dello schermo, non utilizzare un in LinearLayoutquanto sono pensati per visualizzare un numero di elementi in una riga.

Usa RelativeLayoutinvece un .

Quindi sostituire:

android:layout_gravity="center_vertical|center_horizontal"

per l' RelativeLayoutopzione pertinente :

android:layout_centerInParent="true"

Quindi il tuo file di layout sarà simile al seguente:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout android:id="@+id/RelativeLayout01" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">

    <ImageButton android:id="@+id/btnFindMe" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:background="@drawable/findme"></ImageButton>

</RelativeLayout>

38
Ci sono casi in cui è necessario utilizzare un LinearLayout e centrare il contenuto. Questa non dovrebbe essere la risposta accettata. Sarebbe meglio suggerire di utilizzare un RelativeLayout, se possibile, e in caso contrario come centrare in un LinearLayout.
stevebot,

Per non parlare del fatto che un RelativeLayout richiede molto più tempo di esecuzione a causa del modo in cui devono essere misurate le loro dimensioni, mentre un LinearLayout è super semplice e molto più efficiente.
Trevor Hart,

436

Centra usando un LinearLayout:

<LinearLayout
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical" >

    <ImageButton
        android:id="@+id/btnFindMe"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/findme" />
</LinearLayout>

11
LinearLayout è più semplice e leggero rispetto a RelayLayout, dovrebbe essere un po 'più veloce.
SurlyDre,

3
Stavo usando layout_gravity invece di gravità. cambiando in android: gravity = "center" risolto questo problema per me. errore da principiante.
Akushiw,

@ackushiw era anche il mio problema!
Denny,

Almeno per me android: l'attributo LinearLayout dell'attributo gravity = "center" ha funzionato. Grazie Fratello!
tthreetorch,

42

Hai provato a definire android:gravity="center_vertical|center_horizontal"all'interno del layout e l'impostazione android:layout_weight="1"nell'immagine?


2
Mi piace questa opzione che mi permette di mantenere il mio LinearLayout! (Non ho dovuto impostare android:weight="1"il pulsante per centrarlo però.)
Sébastien,

4
android: la gravità non funziona per me in un LinearLayout orizzontale, ma android: layout_gravity funziona.
jfritz42,

35

Un metodo comunemente usato che funziona con layout lineare è quello di impostare una proprietà sul pulsante immagine

android:layout_gravity="center"

È possibile scegliere se allineare a sinistra, allineare al centro o allineare a destra ciascun oggetto nel layout lineare. Si noti che la riga sopra è esattamente la stessa di

android:layout_gravity="center_vertical|center_horizontal"

4
Aggiungi la proprietà android: gravity = "center" nel layout principale - che contiene il tuo pulsante (componenti figlio).
Shekh Akther,

hai anche bisogno di android.orientation = "vertical" più layout_gravity nel genitore, noto anche come elemento LInearLayout ....
Joe Healy,


8

Se lo usi LinearLayoutpuoi aggiungere il centro di gravità:

<LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:gravity="center">
            <Button
            android:layout_width="200dp"
            android:layout_height="wrap_content"
            />
</LinearLayout>`

7

facile con questo

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:visibility="visible" 
        android:gravity="center"
        android:orientation="vertical" >

        <ProgressBar
            android:id="@+id/pbEndTrip"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            />

        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="10dp"
            android:gravity="center"
            android:text="Gettings" />
    </LinearLayout>


5
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">

    <ImageButton android:id="@+id/btnFindMe" 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content"
        android:layout_gravity = "center"
        android:background="@drawable/findme">
    </ImageButton>

</LinearLayout>

Il codice sopra funzionerà.


2

campione completo e funzionante dalla mia macchina ...

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:orientation="vertical"
    tools:context=".MainActivity"
    android:gravity="center"
    android:textAlignment="center">


    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="My Apps!"
        android:id="@+id/textView"
        android:gravity="center"
        android:layout_marginBottom="20dp"
     />

    <Button
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:text="SPOTIFY STREAMER"
        android:id="@+id/button_spotify"
        android:gravity="center"
        android:layout_below="@+id/textView"
        android:padding="20dp"
        />

    <Button
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:text="SCORES"
        android:id="@+id/button_scores"
        android:gravity="center"
        android:layout_below="@+id/textView"
        android:padding="20dp"
        />


    <Button
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:text="LIBRARY APP"
        android:id="@+id/button_library"
        android:gravity="center"
        android:layout_below="@+id/textView"
        android:padding="20dp"
        />

    <Button
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:text="BUILD IT BIGGER"
        android:id="@+id/button_buildit"
        android:gravity="center"
        android:layout_below="@+id/textView"
        android:padding="20dp"
        />

    <Button
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:text="BACON READER"
        android:id="@+id/button_bacon"
        android:gravity="center"
        android:layout_below="@+id/textView"
        android:padding="20dp"
        />

    <Button
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:text="CAPSTONE: MY OWN APP"
        android:id="@+id/button_capstone"
        android:gravity="center"
        android:layout_below="@+id/textView"
        android:padding="20dp"
        />

</LinearLayout>


puoi utilizzare 'android: layout_below' solo sui fratelli di 'RelativeLayout'
jazz,

2

Secondo la documentazione Android per gli attributi XML di Android: layout_gravity , possiamo farlo facilmente :)

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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/btnFindMe" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content"

        android:layout_gravity="center"

        android:background="@drawable/findme"></ImageButton>

</LinearLayout>

1
android: layout_gravity = "center" funziona bene :) grazie!
Amine Soumiaa,

1

Impostare su true android:layout_alignParentTop="true"e android:layout_centerHorizontal="true"nel pulsante, in questo modo:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >
     <Button
        android:id="@+id/switch_flashlight"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/turn_on_flashlight"
        android:textColor="@android:color/black"
        android:onClick="action_trn"
        android:background="@android:color/holo_green_light"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:padding="5dp" />
</RelativeLayout>

inserisci qui la descrizione dell'immagine


0

Puoi anche provare questo codice:

<LinearLayout
            android:id="@+id/linear_layout"
            android:layout_width="fill_parent"
            android:layout_height="0dp"
            android:layout_gravity="center"
            android:orientation="horizontal"
            android:weightSum="2.0"
            android:background="@drawable/anyBackground" >

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:orientation="vertical"
            android:layout_weight="1" >

            <ImageView
                android:id="@+id/img_mail"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:background="@drawable/yourImage" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:orientation="vertical"
            android:layout_weight="1" >



<ImageView
            android:id="@+id/img_save"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:layout_gravity="center"
            android:background="@drawable/yourImage" />
        </LinearLayout>
        </LinearLayout>

Puoi spiegare come questo è diverso dalle risposte già fornite?
EWit

0

basta usare (per farlo al centro del layout)

        android:layout_gravity="center" 

e usare

         android:layout_marginBottom="80dp"

         android:layout_marginTop="80dp"

per cambiare posizione


0

È inoltre possibile impostare la larghezza della LinearLayout ad wrap_contente l'uso android:layout_centerInParent, android:layout_centerVertical="true":

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_centerInParent="true"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
>

<ImageButton android:id="@+id/btnFindMe" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content"       
    android:background="@drawable/findme"/>


0

Questo funziona per me.

android:layout_alignParentEnd="true"

-2

Hai provato questo?

  <TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/mainlayout" android:orientation="vertical"
android:layout_width="fill_parent" android:layout_height="fill_parent">
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:padding="5px"
android:background="#303030"
>
    <RelativeLayout
    android:id="@+id/widget42"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    >
    <ImageButton
    android:id="@+id/map"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="map"
    android:src="@drawable/outbox_pressed"
    android:background="@null"
    android:layout_toRightOf="@+id/location"
    />
    <ImageButton
    android:id="@+id/location"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="location"
    android:src="@drawable/inbox_pressed"
    android:background="@null"
    />
    </RelativeLayout>
    <ImageButton
    android:id="@+id/home"
    android:src="@drawable/button_back"
    android:background="@null"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerVertical="true"
    />
</RelativeLayout>
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:padding="5px"
android:orientation="horizontal"
android:background="#252525"
>
    <EditText
    android:id="@+id/searchfield"
    android:layout_width="fill_parent"
    android:layout_weight="1"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    android:background="@drawable/customshape"
    />
    <ImageButton
    android:id="@+id/search_button"
    android:src="@drawable/search_press"
    android:background="@null"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerVertical="true"
    />
</LinearLayout>
<com.google.android.maps.MapView
    android:id="@+id/mapview" 
    android:layout_weight="1"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content" 
    android:clickable="true"
    android:apiKey="apikey" />

</TableLayout>

-2

uso

Android: layout_centerHorizontal = "true"


1
In realtà vogon101, questa è una proprietà valida in un RelativeLayout. :) Tuttavia, non risponde alla domanda, poiché l'utente utilizzava un LinearLayout e voleva centrare sia in verticale che in orizzontale.
Sarah,

-7

Sarebbe più facile usare i layout relativi, ma per i layout lineari di solito mi concentro assicurandomi che la larghezza corrisponda al genitore:

    android:layout_width="match_parent"

e quindi dai margini a destra e sinistra di conseguenza.

    android:layout_marginLeft="20dp"
    android:layout_marginRight="20dp"
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.