在分隔线上居中LinearLayout

时间:2017-01-12 14:12:53

标签: android android-linearlayout

我想问一下是否有办法将LinearLayout置于其分隔符上,而不是内容?

我想把一个细胞的宽度复制到另一个细胞,所以两者都是相同的 这就是我想要实现的目标:

这是布局:

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

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

                <TextView
                    android:id="@+id/savings_accumulated_percentage_value_label"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Zrealizowano:"

                    android:layout_gravity="end"
                    />


                <TextView
                    android:id="@+id/savings_accumulated_value_label"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Zgromadzono:"

                    android:layout_gravity="end"

                    />

                <TextView
                    android:id="@+id/savings_target_value_label"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Cel:"

                    android:layout_gravity="end"

                    />

                <TextView
                    android:id="@+id/savings_target_date_label"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Data zakończenia:"

                    android:layout_gravity="end"
                    />

            </LinearLayout>

            <LinearLayout
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:orientation="vertical">


                <TextView
                    android:id="@+id/savings_accumulated_percentage_value"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="18%"
                    android:textColor="@color/colorAccent" />

                <TextView
                    android:id="@+id/savings_accumulated_value"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="865 zł"
                    android:textStyle="bold" />

                <TextView
                    android:id="@+id/savings_target_value"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="2 865 zł"
                    android:textColor="@color/colorPrimary"
                    android:textStyle="bold"

                    />

                <TextView
                    android:id="@+id/savings_target_date"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="03.07.2018"
                    />

            </LinearLayout>


        </LinearLayout>

enter image description here

1 个答案:

答案 0 :(得分:1)

您可以在子布局上使用父布局的android:weightSum属性和android:weight属性来实现此目的。

一般规则是weightSum =所有直系孩子的所有权重的总和(在下面的例子中,它的2 = 1 + 1)。虽然如果权重不相等,你不会得到任何错误,但结果可能不像你期望的那样。

这是一个简单的例子。

 <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    android:layout_centerInParent="true"
    android:weightSum="2">  <!-- weightSum property -->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1">  <!-- weight property -->
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:text="hello"/>
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"> <!-- weight property -->
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:text="hi"/>
    </LinearLayout>
</LinearLayout>