我有3个观点:A,B,C。 (A和B的高度相等)在开始时B的可见性消失了,C的顶部约束是A的底部,因此C出现在A之下。经过一段时间后,我将A的可见性更改为走了,B看得见。会发生什么事情是C被拖到顶部,因为A的可见性消失了。我想要做的是将C的顶部约束设置为B的底部。我该怎么做?我需要以编程方式进行。
以下是我现在的位置 - >
os.fork()
<?xml version="1.0" encoding="utf-8"?>
答案 0 :(得分:0)
欢迎您使用 ConstraintSet ,但如果您想保持简单,我想提醒您
ConstraintLayout对小部件的特定处理标记为View.GONE。
像往常一样,GONE小部件不会显示,也不会显示 布局本身(即它们的实际尺寸不会改变) 如果标记为GONE)。但就布局计算而言,GONE小部件仍然是其中的一部分 它具有重要的区别:
对于布局传递,其尺寸将被视为零 (基本上,他们将被解决到一个点)如果他们有约束 对于其他小部件,他们仍将受到尊重,但任何利润都将受到尊重 好像等于零 查看here
让我用简单的布局来演示。
<?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"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".LoginActivity">
<EditText // View A
android:id="@+id/email"
android:hint="email"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
android:ems="10"
android:inputType="textEmailAddress"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<EditText // View B
android:id="@+id/password"
android:hint="password"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
android:ems="10"
android:visibility="gone"
android:inputType="textPassword"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/email" />
<EditText //View C
android:id="@+id/otp"
android:hint="otp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
android:ems="10"
android:inputType="textPassword"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/password" />
<Button
android:id="@+id/login"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:text="Login"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" />
</android.support.constraint.ConstraintLayout>
此布局类似于
当您设置电子邮件字段,即视图A消失
时将密码设置为GONE时,即查看B
这是Constraint布局的神奇之处。