4

我是第一次尝试,但在MotionLayout更改.TextInputLayoutsMotionScene

motion_scene.xml

<?xml version="1.0" encoding="utf-8"?>
<MotionScene
        xmlns:motion="http://schemas.android.com/apk/res-auto"
        xmlns:android="http://schemas.android.com/apk/res/android">

    <Transition
            motion:constraintSetStart="@id/afinstall"
            motion:constraintSetEnd="@id/signin"
            motion:duration="1000">

        <OnClick
                motion:targetId="@id/button_sign_in"
                motion:clickAction="transitionToEnd"/>

        <OnClick

        />

    </Transition>

    <Transition
            motion:constraintSetEnd="@id/afinstall"
            motion:constraintSetStart="@id/signin"
            motion:duration="1000">

        <OnClick
                motion:targetId="@id/button_back"
                motion:clickAction="transitionToEnd"/>

        <OnClick

        />

    </Transition>

    .............

    <ConstraintSet android:id="@+id/afinstall">

        ....

        <Constraint
                android:layout_width="282dp"
                android:layout_height="wrap_content"
                android:hint="Username"
                android:layout_marginEnd="8dp"
                motion:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="8dp"
                motion:layout_constraintStart_toStartOf="parent" android:id="@+id/sign_in_username_tf"
                android:layout_marginTop="1dp" motion:layout_constraintTop_toBottomOf="@+id/app_slogan"
                android:visibility="gone" />
        <Constraint
                android:layout_width="282dp"
                android:layout_height="wrap_content"
                android:hint="Password"
                android:layout_marginStart="8dp"
                motion:layout_constraintStart_toStartOf="parent" android:layout_marginEnd="8dp"
                motion:layout_constraintEnd_toEndOf="parent" android:id="@+id/sign_in_password_tf"
                android:layout_marginTop="1dp" motion:layout_constraintTop_toBottomOf="@+id/sign_in_username_tf"
                android:visibility="gone"/>

         ....
    </ConstraintSet>

    <ConstraintSet android:id="@+id/signin">

    ....

    <Constraint
                android:layout_width="282dp"
                android:layout_height="wrap_content"
                android:hint="Username"
                android:layout_marginEnd="8dp"
                motion:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="8dp"
                motion:layout_constraintStart_toStartOf="parent" android:id="@+id/sign_in_username_tf"
                android:layout_marginTop="110dp" motion:layout_constraintTop_toBottomOf="@+id/app_slogan"
                android:visibility="visible"/>
        <Constraint
                android:layout_width="282dp"
                android:layout_height="wrap_content"
                android:hint="Password"
                android:layout_marginTop="15dp"
                motion:layout_constraintTop_toBottomOf="@+id/sign_in_username_tf" android:layout_marginStart="8dp"
                motion:layout_constraintStart_toStartOf="parent" android:layout_marginEnd="8dp"
                motion:layout_constraintEnd_toEndOf="parent" android:id="@+id/sign_in_password_tf"
                android:visibility="visible"/>

    ....

    </ConstraintSet>

</MotionScene>

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.motion.MotionLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layoutDescription="@xml/motion_scene"
        tools:context=".MainActivity">

....

    <android.support.design.widget.TextInputLayout
            android:layout_width="282dp"
            android:layout_height="wrap_content"
            android:hint="Username"
            android:layout_marginEnd="8dp"
            app:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="8dp"
            app:layout_constraintStart_toStartOf="parent" android:id="@+id/sign_in_username_tf"
            android:layout_marginTop="1dp" app:layout_constraintTop_toBottomOf="@+id/app_slogan"
            android:visibility="gone">

        <android.support.design.widget.TextInputEditText
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:fontFamily="@font/nunito_sans" android:textSize="20sp"
                android:textColor="@color/colorPrimaryLi"/>
    </android.support.design.widget.TextInputLayout>
    <android.support.design.widget.TextInputLayout
            android:layout_width="282dp"
            android:layout_height="wrap_content"
            android:hint="Password" app:hintEnabled="true"
            app:hintAnimationEnabled="true"
            android:layout_marginStart="8dp"
            app:layout_constraintStart_toStartOf="parent" android:layout_marginEnd="8dp"
            app:layout_constraintEnd_toEndOf="parent" android:id="@+id/sign_in_password_tf"
            android:layout_marginTop="1dp" app:layout_constraintTop_toBottomOf="@+id/sign_in_username_tf"
            android:visibility="gone">

        <android.support.design.widget.TextInputEditText
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:fontFamily="@font/nunito_sans" android:textSize="20sp"
                android:textColor="@color/colorPrimaryLi"/>
    </android.support.design.widget.TextInputLayout>

    ....

</android.support.constraint.motion.MotionLayout>

我试过摆弄东西,但我无法指出它为什么会发生。

请不要将此标记为重复,因为这是我正在尝试的一个相当新的库。如果需要,我很乐意进一步详细说明。

4

3 回答 3

3

我发现当前(alpha 5)可见性 cange 不起作用(如果您在约束集中设置它会起作用,但在事件或关键帧集上不起作用)作为一种解决方法,我使用 alpha 0-1 使视图可见或不可见并添加 incode听众使其可点击

于 2019-05-25T11:33:47.393 回答
1

你必须使用<KeyFrameSet>inside<Trasition>并重新定义<KeyAttribute>

于 2019-06-18T08:13:44.100 回答
0

您可以尝试将可见性声明为自定义属性,而不是在约束上声明可见性。因此,对于您的第一个约束,请尝试以下操作:

 <Constraint
            android:layout_width="282dp"
            android:layout_height="wrap_content"
            android:hint="Username"
            android:layout_marginEnd="8dp"
            motion:layout_constraintEnd_toEndOf="parent" 
            android:layout_marginStart="8dp"
            motion:layout_constraintStart_toStartOf="parent" 
            android:id="@+id/sign_in_username_tf"
            android:layout_marginTop="1dp"
            motion:layout_constraintTop_toBottomOf="@+id/app_slogan" >
    <CustomAttribute
        motion:attributeName="visibility"
        motion:customIntegerValue="8" />
</Constraint>

通过将可见性声明为自定义属性,这应该有助于运动布局在可见性值之间正确插入。哪个 int 值是哪个可见性有点不直观,但它们的定义如下

Visible = 0
Invisible = 4
Gone = 8
于 2020-02-20T18:11:03.723 回答