Android约束布局动画
在本教程中,我们将在Android应用程序中实现约束布局动画。
约束布局动画
我们可以使用ConstraintLayout快速创建精美的动画。
为此,我们只需要更改约束即可!
通过创建两个不同的布局来创建约束布局动画的最常见,最简单的方法。
第一个是动画的开始阶段,第二个是动画的结束阶段。
Constraint Set是用于在Constraint Layout的视图上设置约束的类。
约束集
ConstraintSet是用于以编程方式在"约束布局"上定义约束的类。
它也可以使用clone()方法检索约束布局中存在的约束。
clone()方法用于从布局复制约束。
applyTo()用于将约束集应用于约束布局。
与其他任何Java对象一样,创建ConstraintSet:
ConstraintSet constraintSet = new ConstraintSet();
为了以编程方式对视图设置约束,我们需要使用connect()。
connect()在同级视图或者视图与父视图之间建立连接。
要创建ConstraintLayout动画,我们需要:
TransitionManager–管理过渡。
" beginDelayedTransition()" –开始从第一个场景到第二个场景(从第一个布局到第二个布局)的过渡。
applyTo()–在第二个布局上应用最终约束。
这意味着您需要创建重复的XML布局,不同之处在于约束。
第一个布局应在过渡的初始阶段显示约束。
第二个布局应在动画之后显示约束。
这样过渡就发生了!
您无需在重复的XML中设置属性和样式。
它会从第一个开始自动捕获。
要使用ConstraintSet,XML布局中的每个视图都必须具有一个ID。
代码
下面给出了activity_main.xml布局的代码:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="https://schemas.android.com/apk/res/android"
xmlns:app="https://schemas.android.com/apk/res-auto"
xmlns:tools="https://schemas.android.com/tools"
android:id="@+id/cc1"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<ImageView
android:id="@+id/backgroundImage"
android:layout_width="0dp"
android:layout_height="0dp"
android:scaleType="centerCrop"
android:src="@drawable/bg"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
<EditText
android:id="@+id/inPassword"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:hint="Password"
android:paddingBottom="8dp"
android:paddingEnd="24dp"
android:paddingStart="24dp"
android:paddingTop="8dp"
android:textColor="#FFFF"
android:background="@drawable/input_field"
android:imeOptions="actionNext"
android:inputType="textPassword"
android:maxLines="1"
android:layout_margin="16dp"
android:textColorHint="#b3ffffff"
android:textCursorDrawable="@null"
app:layout_constraintBottom_toBottomOf="@+id/inUsername"
app:layout_constraintLeft_toRightOf="@+id/backgroundImage"
<EditText
android:id="@+id/inUsername"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="48dp"
android:hint="Username"
android:paddingBottom="8dp"
android:paddingEnd="24dp"
android:paddingStart="24dp"
android:paddingTop="8dp"
android:textColor="#FFFF"
android:background="@drawable/input_field"
android:imeOptions="actionNext"
android:inputType="textEmailAddress"
android:maxLines="1"
android:layout_margin="16dp"
android:textColorHint="#b3ffffff"
android:textCursorDrawable="@null"
app:layout_constraintRight_toLeftOf="@+id/backgroundImage"
app:layout_constraintTop_toTopOf="parent"
<TextView
android:id="@+id/tap"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="12dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:text="Tap to animate"
android:textColor="#ffffff"
android:textSize="15sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
<Button
android:id="@+id/btnLogin"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="#181818"
android:gravity="center"
android:text="LOGIN"
android:textColor="#FFFF"
android:textSize="18sp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@+id/backgroundImage"
</android.support.constraint.ConstraintLayout>
可绘制input_field.xml的代码可以在本教程结尾处提供的源代码/github存储库中找到。
最终的" activity_main_animated.xml"布局的代码是:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="https://schemas.android.com/apk/res/android"
xmlns:app="https://schemas.android.com/apk/res-auto"
xmlns:tools="https://schemas.android.com/tools"
android:id="@+id/cc2"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<ImageView
android:id="@+id/backgroundImage"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="centerCrop"
android:src="@drawable/bg"
app:layout_constraintBottom_toTopOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
<EditText
android:id="@+id/inUsername"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="16dp"
android:paddingBottom="8dp"
android:paddingEnd="24dp"
android:paddingStart="24dp"
android:paddingTop="8dp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toTopOf="parent"
<EditText
android:id="@+id/inPassword"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="16dp"
android:paddingBottom="8dp"
android:paddingEnd="24dp"
android:paddingStart="24dp"
android:paddingTop="8dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/inUsername"
<TextView
android:id="@+id/tap"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
<Button
android:id="@+id/btnLogin"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="16dp"
android:gravity="center"
android:textSize="18sp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@+id/inPassword"
</android.support.constraint.ConstraintLayout>
MainActivity.java的代码如下:
package com.theitroad.androidconstraintanimation;
import android.support.constraint.ConstraintLayout;
import android.support.constraint.ConstraintSet;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.transition.ChangeBounds;
import android.transition.TransitionManager;
import android.view.View;
import android.view.animation.AnticipateInterpolator;
import android.widget.ImageView;
public class MainActivity extends AppCompatActivity {
ImageView imageView;
boolean show = false;
ConstraintLayout cc1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
cc1 = findViewById(R.id.cc1);
imageView = findViewById(R.id.backgroundImage);
imageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (show)
revertAnimation();
else
showAnimation();
}
});
}
private void showAnimation() {
show = true;
ConstraintSet constraintSet = new ConstraintSet();
constraintSet.clone(this, R.layout.activity_main_animation);
ChangeBounds transition = new ChangeBounds();
transition.setInterpolator(new AnticipateInterpolator(1.0f));
transition.setDuration(1200);
TransitionManager.beginDelayedTransition(cc1, transition);
constraintSet.applyTo(cc1);
}
private void revertAnimation() {
show = false;
ConstraintSet constraintSet = new ConstraintSet();
constraintSet.clone(this, R.layout.activity_main);
ChangeBounds transition = new ChangeBounds();
transition.setInterpolator(new AnticipateInterpolator(1.0f));
transition.setDuration(1200);
TransitionManager.beginDelayedTransition(cc1, transition);
constraintSet.applyTo(cc1);
}
}
在TransitionManager内,我们设置了一个插值器类,该类具有预定义的行为。

