我有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>
稍微玩一下后,为了使取消按钮与删除按钮水平对齐,我必须在取消按钮中添加以下任一项。
app:layout_constraintBaseline_toBaselineOf="@+id/btn_delete"
或
app:layout_constraintVertical_bias="0.0"
问题:
为什么ConstraintLayout按下了取消按钮而不是将其与删除按钮对齐?为什么我必须在取消按钮上使用基线或偏差才能使其在同一条线上对齐?
除了使用基线和偏差外,还有其他方法可以使取消按钮与删除按钮对齐吗?
答案 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"
您将获得以下布局
请注意,delete
和cancel
按钮现在以相同方式对齐。原因是现在delete
和取消按钮都有以下约束
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_save"
两个按钮在save
按钮和父版面底部之间垂直居中。
除了使用基线和偏见外,还有其他方法吗? 取消按钮是否与删除按钮对齐?
有多种方法可以实现所需的布局
一种方法是删除
app:layout_constraintBottom_toBottomOf="parent"
来自cancel
和delete
按钮并更改
app:layout_constraintBottom_toTopOf="@+id/btn_delete"
到
app:layout_constraintBottom_toBottomOf="parent"
在save
按钮布局中。
这将为您提供以下布局
此方法有效,因为删除bottom constraint
会使cancel
和delete
按钮同时未在save
按钮和CustomerModel.findOne({_id: ObjectId(args._id)})
按钮之间的空间中垂直居中。父布局的底部。