在ConstraintLayout中的另一个视图下水平居中两个视图

时间:2018-02-07 05:22:40

标签: android android-constraintlayout

我有3个按钮,一个全宽按钮位于屏幕半宽的两个按钮的顶部。这是布局:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <Button
        android:id="@+id/btn_save"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="Save"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toTopOf="@+id/btn_delete"
        app:layout_constraintVertical_chainStyle="packed"/>
    <Button
        android:id="@+id/btn_delete"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="Delete"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toLeftOf="@+id/btn_cancel"
        app:layout_constraintTop_toBottomOf="@+id/btn_save" />
    <Button
        android:id="@+id/btn_cancel"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:text="Cancel"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toRightOf="@+id/btn_delete"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btn_save"/>
</android.support.constraint.ConstraintLayout>

结果是取消按钮被按下而不是在水平线上与删除按钮对齐。 enter image description here

稍微玩一下后,为了使取消按钮与删除按钮水平对齐,我必须在取消按钮中添加以下任一项。

app:layout_constraintBaseline_toBaselineOf="@+id/btn_delete"

app:layout_constraintVertical_bias="0.0"

问题:

  1. 为什么ConstraintLayout按下了取消按钮而不是将其与删除按钮对齐?为什么我必须在取消按钮上使用基线或偏差才能使其在同一条线上对齐?

  2. 除了使用基线和偏差外,还有其他方法可以使取消按钮与删除按钮对齐吗?

2 个答案:

答案 0 :(得分:5)

app:layout_constraintBottom_toBottomOf="parent"

中删除btn_cancel
 <?xml version="1.0" encoding="utf-8"?>
    <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <Button
            android:id="@+id/btn_save"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:text="Save"
            app:layout_constraintBottom_toTopOf="@+id/btn_delete"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_chainStyle="packed" />

        <Button
            android:id="@+id/btn_delete"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:text="Delete"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toLeftOf="@+id/btn_cancel"
            app:layout_constraintTop_toBottomOf="@+id/btn_save" />

        <Button
            android:id="@+id/btn_cancel"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:text="Cancel"
            app:layout_constraintLeft_toRightOf="@+id/btn_delete"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/btn_save" />
    </android.support.constraint.ConstraintLayout>

删除 app:layout_constraintVertical_chainStyle="packed"有关详细信息,请查看chainStyle https://developer.android.com/training/constraint-layout/index.html#constrain-chain

答案 1 :(得分:5)

  

为什么ConstraintLayout按下取消按钮而不是   将它与删除按钮对齐?为什么我必须使用基线   或偏置取消按钮,以使其对齐   线?

cancel按钮被按下,因为当您在cancel按钮上设置了以下两个约束时

app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_save"

cancel按钮在save按钮与父版式底部之间垂直居中

现在您可能会问 delete按钮也有相同的两个约束,那么为什么它不像cancel按钮那样被按下呢? 原因,您已在save按钮

上设置了以下约束
app:layout_constraintBottom_toTopOf="@+id/btn_delete"

如果您将其更改为

app:layout_constraintBottom_toTopOf="@+id/btn_cancel"

delete按钮将被按下,cancel按钮将与save按钮对齐。

如果您将其更改为

app:layout_constraintBottom_toBottomOf="parent"

您将获得以下布局

enter image description here

请注意,deletecancel按钮现在以相同方式对齐。原因是现在delete和取消按钮都有以下约束

app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_save"

两个按钮在save按钮和父版面底部之间垂直居中

  

除了使用基线和偏见外,还有其他方法吗?   取消按钮是否与删除按钮对齐?

有多种方法可以实现所需的布局

一种方法是删除

app:layout_constraintBottom_toBottomOf="parent" 

来自canceldelete按钮并更改

app:layout_constraintBottom_toTopOf="@+id/btn_delete"

app:layout_constraintBottom_toBottomOf="parent"

save按钮布局中。

这将为您提供以下布局

enter image description here

此方法有效,因为删除bottom constraint会使canceldelete按钮同时未在save按钮和CustomerModel.findOne({_id: ObjectId(args._id)})按钮之间的空间中垂直居中。父布局的底部。