Android对齐按钮居中并确保它们均匀分布

时间:2015-06-09 13:06:30

标签: android xml button android-layout-weight

enter image description here

我有一个带有四个按钮(附带)的主菜单,我想将所有按钮对齐到中心(包括"主菜单" textView),我想确保每个按钮均匀分布均匀。

我添加了android:gravity =" center">但它没有与中心对齐。也是为了均匀地分隔按钮,我试图添加android:layout_weight =" 1"作为Button属性之一,但我的按钮从屏幕上消失。

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:gravity="center">

   <TextView android:text="Main Menu" 
             android:layout_width="wrap_content"
             android:layout_height="wrap_content" />
    <Button android:text="Button" 
            android:id="@+id/button1"
            android:layout_width="wrap_content" 
            android:layout_height="0dp"/>
    <Button android:text="Button" 
            android:id="@+id/button2"
            android:layout_width="wrap_content" 
            android:layout_height="0dp"/>
    <Button android:text="Button" 
            android:id="@+id/button3"
            android:layout_width="wrap_content" 
            android:layout_height="0dp"/>
    <Button android:text="Button" 
            android:id="@+id/button4"
            android:layout_width="wrap_content" 
            android:layout_height="0dp"/>

</LinearLayout>

3 个答案:

答案 0 :(得分:1)

如果要设置0dp,则无需硬编码视图的高度或waight then only height is 0dp。检查我在这里给出的所有行。

试试这个:

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

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Main Menu" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

    <Button
        android:id="@+id/button4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

</LinearLayout>

答案 1 :(得分:1)

将LinearLayout的宽度和高度从wrap_content更改为match_parent .. like this ..

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center">

   <TextView android:text="Main Menu" 
             android:layout_width="wrap_content"
             android:layout_height="wrap_content" />
    <Button android:text="Button" 
            android:id="@+id/button1"
            android:layout_width="wrap_content" 
            android:layout_height="55dp"/>
    <Button android:text="Button" 
            android:id="@+id/button2"
            android:layout_width="wrap_content" 
            android:layout_height="55dp"/>
    <Button android:text="Button" 
            android:id="@+id/button3"
            android:layout_width="wrap_content" 
            android:layout_height="55dp"/>
    <Button android:text="Button" 
            android:id="@+id/button4"
            android:layout_width="wrap_content" 
            android:layout_height="55dp"/>

</LinearLayout>

答案 2 :(得分:0)

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:layout_gravity="center_horizontal"
android:orientation="vertical" >

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Main Menu" />

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button" />

<Button
    android:id="@+id/button2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button" />

<Button
    android:id="@+id/button3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button" />

<Button
    android:id="@+id/button4"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button" />

</LinearLayout>