線形レイアウトでボタンを中央に配置する


338

線形レイアウトを使用して、かなり明るい初期画面を表示しています。これには、画面の水平方向と垂直方向の両方の中央に配置されるボタンが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>

6
水平方向の配置を使用したLinearLayoutでそれを修正したのは、layout_width「wrap_content」に設定することでした。その後、layout_gravityそれがすることになっていたことをしました!
誰かどこか

あなたは厳密のLinearLayoutを使用する必要がある場合、私は、これは動作するはずだと思う:stackoverflow.com/questions/18051472/...を
アントニオ

回答:


372

画面の中央にアイテムを中央に配置する場合は、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 2015年

LinearLayoutは非常に単純で効率的であるのに対し、RelativeLayoutは寸法を測定する方法が原因で実行時の負荷がはるかに高くなることは言うまでもありません。
Trevor Hart

廃止されましたか?エラーがあります。
瀧谷賢司

436

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は、RelativeLayoutに比べてシンプルで軽量で、少し高速です。
SurlyDre 2013年

3
重力の代わりにlayout_gravityを使用していました。android:gravity = "center"に変更すると、これが修正されました。新人間違い。
ackushiw

@ackushiwも私の問題でした!
デニー

少なくとも私にとっては、android:gravity = "center" LinearLayout属性がうまく機能しました。仲間ありがとう!
tthreetorch

42

画像のandroid:gravity="center_vertical|center_horizontal"レイアウトと設定の内部を定義してみandroid:layout_weight="1"ましたか?


2
私はmi LinearLayoutを維持できるこのオプションが好きです!(android:weight="1"ただし、ボタンを中央に配置するためにボタンを設定する必要はありませんでした。)
セバスチャン

4
水平方向のLinearLayoutでは、android:gravityは機能しませんが、android:layout_gravityは機能します。
jfritz42 2012年

35

線形レイアウトで機能する一般的に使用される方法は、画像ボタンにプロパティを設定することです

android:layout_gravity="center"

線形レイアウトで各オブジェクトを左揃え、中央揃え、または右揃えにするかどうかを選択できます。上記の行は正確に同じであることに注意してください

android:layout_gravity="center_vertical|center_horizontal"

4
ボタン(子コンポーネント)を保持するandroid:gravity = "center"プロパティを親レイアウトに追加します。
シェクアクサー2013年

また、android.orientation = "vertical"と親のlayout_gravity(別名LInearLayout要素)も必要です。–
Joe Healy


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
<?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'の兄弟でのみ使用できます
jazz

2

android:layout_gravityの XML属性に関するAndroidドキュメントに従って、簡単に行うことができます:)

<?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"は正常に動作します:)ありがとうございます!
アミンSoumiaa 2018年

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>

ここに画像の説明を入力してください


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>

これがすでに提供されている回答とどのように異なるのか説明できますか?
EWit

0

(レイアウトの中央に配置する)を使用するだけです

        android:layout_gravity="center" 

そして使う

         android:layout_marginBottom="80dp"

         android:layout_marginTop="80dp"

位置を変更する


0

あなたはまたにのLinearLayoutの幅を設定することができますwrap_contentし、使用android:layout_centerInParentandroid: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

これは私のために働いています。

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

使用する

android:layout_centerHorizo​​ntal = "true"


1
実際にはvogon101、これはRelativeLayoutの有効なプロパティです。:)ユーザーはLinearLayoutを使用していて、垂直方向と水平方向の両方に中央揃えしたかったので、それは質問には答えません。
サラ

-7

相対レイアウトを使用する方が簡単ですが、線形レイアウトの場合、通常、幅が親と一致することを確認することで中央揃えにします。

    android:layout_width="match_parent"

そして、それに応じて左右にマージンを与えるだけです。

    android:layout_marginLeft="20dp"
    android:layout_marginRight="20dp"
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.