Android:Constraint Layout Set Constraint top编程顶部?

时间:2018-05-30 05:17:30

标签: java android android-layout kotlin android-constraintlayout

我有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"?>

1 个答案:

答案 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>

此布局类似于

All fields visible

当您设置电子邮件字段,即视图A消失

View A visibility GONE here

密码设置为GONE时,即查看B

View B visibility is GONE

这是Constraint布局的神奇之处。