最近尝试实现 Constraint Layout,但我发现 Barrier和 Guideline的工作原理是一样的。两者都像分割器一样工作。他们之间有什么区别吗?
Constraint Layout
Barrier
Guideline
关于“障碍”的官方文件:
“障碍”引用多个小部件作为输入,并基于指定端的最极端小部件创建虚拟准则。例如,左边的屏障将与所有引用视图的左边对齐。
障碍训练文件
与指南类似,障碍是一条不可见的线,您可以将视图约束到这条线上。除了一个障碍不定义它自己的位置; 相反,障碍位置移动基于其中包含的视图的位置。当您希望将视图约束为一组视图而不是一个特定视图时,这非常有用。
假设您有两个具有动态高度的 TextView小部件,并且您想在最高的 TextView下面放置一个 Button:
TextView
Button
在布局中直接实现这一点的 强大方法是使用水平 Barrier。该 Barrier允许您基于这两个 TextView的高度指定约束。然后将 Button的顶部约束到水平 Barrier的底部。
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.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"> <TextView android:id="@+id/left_text_view" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginTop="8dp" android:layout_marginEnd="8dp" android:layout_marginStart="8dp" android:text="ABCDEFGHIJKLMNOPQRSTUVWXYZ" android:textSize="16sp" android:background="#AAA" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toStartOf="@+id/right_text_view" app:layout_constraintTop_toTopOf="parent" /> <TextView android:id="@+id/right_text_view" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginTop="8dp" android:layout_marginStart="8dp" android:layout_marginEnd="8dp" android:text="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890" android:textSize="16sp" android:background="#DDD" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toEndOf="@+id/left_text_view" app:layout_constraintTop_toTopOf="parent" /> <androidx.constraintlayout.widget.Barrier android:id="@+id/barrier" android:layout_width="wrap_content" android:layout_height="wrap_content" app:barrierDirection="bottom" app:constraint_referenced_ids="left_text_view,right_text_view" /> <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginEnd="8dp" android:layout_marginStart="8dp" android:text="Button" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="@+id/barrier" /> </androidx.constraintlayout.widget.ConstraintLayout>
假设您想将上面提到的 TextView高度限制在屏幕高度的30% ,不管它们有什么内容。
要实现这一点,您应该添加水平 Guideline与百分比位置和约束的 TextView底部的该 Guideline。
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.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"> <TextView android:id="@+id/left_text_view" android:layout_width="0dp" android:layout_height="0dp" android:layout_marginBottom="8dp" android:layout_marginEnd="8dp" android:layout_marginStart="8dp" android:layout_marginTop="8dp" android:background="#AAA" android:text="ABCDEFGHIJKLMNOPQRSTUVWXYZ" android:textSize="16sp" app:layout_constraintBottom_toTopOf="@+id/guideline" app:layout_constraintEnd_toStartOf="@+id/right_text_view" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" /> <TextView android:id="@+id/right_text_view" android:layout_width="0dp" android:layout_height="0dp" android:layout_marginEnd="8dp" android:layout_marginStart="8dp" android:layout_marginTop="8dp" android:layout_marginBottom="8dp" android:background="#DDD" android:text="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890" android:textSize="16sp" app:layout_constraintBottom_toTopOf="@+id/guideline" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toEndOf="@+id/left_text_view" app:layout_constraintTop_toTopOf="parent" /> <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginEnd="8dp" android:layout_marginStart="8dp" android:text="Button" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="@+id/guideline" /> <androidx.constraintlayout.widget.Guideline android:id="@+id/guideline" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" app:layout_constraintGuide_percent="0.3" /> </androidx.constraintlayout.widget.ConstraintLayout>
Barrier和 Guideline之间的唯一区别是,Barrier的位置是灵活的,并且始终基于其中包含的多个 UI 元素的大小,而且 Guideline的位置始终是固定的。