Центрировать кнопку в линейном макете

339

Я использую линейный макет для отображения довольно легкого начального экрана. Он имеет 1 кнопку, которая должна центрироваться на экране как горизонтально, так и вертикально. Однако независимо от того, что я пытаюсь сделать, кнопка будет выравнивать центр сверху. Я включил XML ниже, кто-нибудь может указать мне правильное направление?

<?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>
themaninthesuitcase
источник
6
То, что исправило это для меня в LinearLayout с горизонтальным выравниванием, было установить layout_widthзначение «wrap_content». Впоследствии он layout_gravityсделал то, что должен был сделать!
Кто-то где-то
Если вам строго необходимо использовать LinearLayout, я думаю, что это должно работать: stackoverflow.com/questions/18051472/…
Антонио

Ответы:

374

Если вы хотите центрировать элемент по центру экрана, не используйте a, так LinearLayoutкак они предназначены для отображения количества элементов в строке.

Используйте RelativeLayoutвместо.

Так что замените:

android:layout_gravity="center_vertical|center_horizontal"

для соответствующего RelativeLayoutварианта:

android:layout_centerInParent="true"

Итак, ваш файл макета будет выглядеть так:

<?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
Есть случаи, когда вам нужно использовать LinearLayout и центрировать контент. Это не должно быть принятым ответом. Было бы лучше предложить по возможности использовать RelativeLayout, а если нет, то как центрировать его в LinearLayout.
Stevebot
Не говоря уже о том, что RelativeLayout намного более интенсивно во время выполнения из-за способа измерения их размеров, в то время как LinearLayout очень прост и намного более эффективен.
Тревор Харт
437

Центр, используя 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>
lancha90
источник
11
LinearLayout проще и легче по сравнению с RelativeLayout, должен быть немного быстрее.
SurlyDre
3
Я использовал layout_gravity вместо гравитации. переход на андроид: gravity = "center" исправил это для меня. ошибка новичка.
Ackushiw
@ackushiw тоже была моей проблемой!
Денни
По крайней мере для меня android: gravity = "center" Атрибут LinearLayout сделал свое дело. Спасибо, брат!
tthreetorch
42

Вы пытались определить android:gravity="center_vertical|center_horizontal"внутри макета и настройки android:layout_weight="1"в изображении?

Руи
источник
2
Мне нравится эта опция, которая позволяет мне сохранить мой LinearLayout! (Мне не нужно было android:weight="1"нажимать кнопку, чтобы отцентрировать ее.)
Себастьян
4
Android: гравитация не работает для меня в горизонтальном LinearLayout, но Android: layout_gravity работает.
jfritz42
35

Обычно используемый метод, который работает с линейным макетом, состоит в том, чтобы установить свойство для кнопки изображения

android:layout_gravity="center"

Вы можете выбрать выравнивание по левому краю, по центру или по правому краю каждого объекта в линейном макете. Обратите внимание, что приведенная выше строка точно такая же, как

android:layout_gravity="center_vertical|center_horizontal"
hopcraft
источник
4
Добавьте свойство android: gravity = "center" в родительский макет, который содержит вашу кнопку (дочерние компоненты).
Шех Актер
вам также нужен android.orientation = "vertical" плюс layout_gravity в родительском элементе, также известный как элемент LInearLayout ....
Джо Хили,
10

Добавь это

android:gravity="center"

В LinearLayout.

Tanmay Sahoo
источник
1
должно быть android:gravity="center"
Джон Джо
8

Если вы используете, LinearLayoutвы можете добавить центр тяжести:

<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

легко с этим

    <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

Вы можете использовать RelativeLayout.

Амит Кумар
источник
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>

Приведенный выше код будет работать.

Вишь
источник
2

полный и рабочий образец с моей машины ...

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

Джо Хили
источник
Вы можете использовать «android: layout_below» только для братьев и сестер «RelativeLayout»
джаз
2

Согласно документации Android для атрибутов XML android: layout_gravity , мы можем сделать это легко :)

<?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" работает отлично :) спасибо!
Амине Соумия
1

Установите в true android:layout_alignParentTop="true"и android:layout_centerHorizontal="true"в кнопке, вот так:

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

введите описание изображения здесь

Oskar
источник
0

Вы также можете попробовать этот код:

<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>
user4058115
источник
Можете ли вы объяснить, чем это отличается от уже предоставленных ответов?
EWit
0

просто используйте (чтобы сделать его в центре вашего макета)

        android:layout_gravity="center" 

и использовать

         android:layout_marginBottom="80dp"

         android:layout_marginTop="80dp"

изменить положение

Мохамед Адель
источник
0

Вы также можете установить ширину LinearLayout к wrap_contentи использования 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"/>

A-Sharabiani
источник
0

Это работает для меня.

android:layout_alignParentEnd="true"
Марси
источник
-2

Ты пробовал это?

  <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

использование

андроид: layout_centerHorizontal = "истина"

Маянк Мишра
источник
1
На самом деле vogon101, это допустимое свойство в RelativeLayout. :) Это не отвечает на вопрос, потому что пользователь использовал LinearLayout и хотел центрировать как вертикально, так и горизонтально.
Сара
-7

Было бы проще использовать относительные макеты, но для линейных макетов я обычно центрирую, убедившись, что ширина соответствует родительской:

    android:layout_width="match_parent"

а затем просто дать поля справа и слева соответственно.

    android:layout_marginLeft="20dp"
    android:layout_marginRight="20dp"
user2090145
источник