不同线性布局的文本视图的垂直对齐

时间:2016-03-19 07:29:14

标签: android android-linearlayout

我正在尝试创建一个显示学生详细信息的屏幕。以下是该屏幕的xml代码。

    <?xml version="1.0" encoding="utf-8"?>

<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:orientation="vertical"
    tools:context=".PatientDetails">

    <LinearLayout
        android:id="@+id/ll1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:layout_weight="3"
        android:background="@color/BackgroundColor">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1">

        </LinearLayout>
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1">
            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Details"
                android:textColor="@color/white"
                android:textSize="30dp"
                android:gravity="center"/>
        </LinearLayout>

    </LinearLayout>

    <LinearLayout
        android:id="@+id/ll2"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:orientation="vertical"
        android:background="@color/white">

        <ScrollView
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical"
                android:padding="16dp">

                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_weight="1"
                    android:orientation="horizontal"
                    android:layout_marginTop="16dp">

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:text="Student Name"
                        android:textSize="20dp"
                        android:layout_weight="1"
                        android:textColor="@color/BackgroundColor"/>
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:id="@+id/PatientName"
                        android:text="Joseph"
                        android:layout_weight="1"
                        android:textSize="20dp"
                        android:textColor="@color/BackgroundColor"/>
                </LinearLayout>
                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_weight="1"
                    android:orientation="horizontal"
                    android:layout_marginTop="16dp">

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:text="Age"
                        android:textSize="20dp"
                        android:layout_weight="1"
                        android:textColor="@color/BackgroundColor"/>
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:id="@+id/age"
                        android:text="21"
                        android:layout_weight="1"
                        android:textSize="20dp"
                        android:textColor="@color/BackgroundColor"/>
                </LinearLayout>
                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_weight="1"
                    android:orientation="horizontal"
                    android:layout_marginTop="16dp">

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:text="Sex"
                        android:textSize="20dp"
                        android:layout_weight="1"
                        android:textColor="@color/BackgroundColor"/>
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:id="@+id/Sex"
                        android:text="Female"
                        android:layout_weight="1"
                        android:textSize="20dp"
                        android:textColor="@color/BackgroundColor"/>
                </LinearLayout>
            </LinearLayout>
        </ScrollView>
    </LinearLayout>
</LinearLayout>

代码的输出如下: enter image description here 有人可以告诉我如何修改代码,以便每行右侧的值正确对齐。

3 个答案:

答案 0 :(得分:2)

行示例:

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginTop="16dp"
            android:orientation="horizontal">

            <TextView
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Student Name"
                android:textColor="@color/BackgroundColor"
                android:textSize="20dp" />

            <TextView
                android:id="@+id/PatientName"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Joseph"
                android:textColor="@color/BackgroundColor"
                android:textSize="20dp" />
        </LinearLayout>

从行根中删除android:layout_weight="1"。将android:layout_width="wrap_content"更改为android:layout_width="0dp"

答案 1 :(得分:0)

<强>示例

 <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="16dp"
                android:orientation="horizontal"
                android:weightSum="2">

                <TextView
                    android:layout_width="0dp"
                    android:layout_height="wrap_content"
                    android:layout_gravity="left"
                    android:layout_weight="1"
                    android:text="Student Name"
                    android:textColor="@color/pika_bg"
                    android:textSize="20dp" />

                <TextView
                    android:id="@+id/PatientName"
                    android:layout_width="0dp"
                    android:layout_height="wrap_content"
                    android:layout_weight="1"
                    android:paddingLeft="5dp"
                    android:text="Joseph"
                    android:textColor="@color/pika_bg"
                    android:textSize="20dp" />
            </LinearLayout>

此处我将android:weightSum="2"添加到了父LinearLayout。这样子视图可以获得相同的宽度。然后我们可以根据您的需要调整填充/重力属性。

答案 2 :(得分:0)

我认为你使用的是线性布局,但线性布局也有一个属性叫做layout_weight,我认为你应该使用它。

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">

    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:text="Test" />

    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:text="Test" />
</LinearLayout>