根据视图如何获得其背景色和如何获得目标颜色,有几种不同的方法可以做到这一点。
用对象动画如果:视图的背景色定义为
argb值在XML文件中。
以前,您的视图的颜色设置为
view.setBackgroundColor()
视图的背景色定义在可绘制的
不定义任何额外的属性,如笔划或角半径。
您的视图具有可绘制的背景色,您希望删除任何额外的属性,如笔画或角半径,请记住,删除额外的属性将不会动画。
对象动画器通过调用view.setBackgroundColor替换定义的可绘制,除非它是ColorDrawable很少是这样的。这意味着,任何额外的背景属性,从一个可绘图,如笔画或角将被删除。
用价值动画如果:您的视图在可绘制中定义了其背景色,该绘图还设置了诸如笔画或角半径之类的属性,您希望将其更改为运行时决定的新颜色。
用过渡拉伸如果:您的视图应该在部署之前定义的两个可绘制的视图之间切换。
在打开DrawerLayout时,我在打开DrawerLayout时遇到了一些性能问题,这些问题是在我打开DrawerLayout时运行的,因此,如果您遇到任何意外的口吃,您可能会遇到与我相同的错误。
如果要使用状态拉出或者是分层拉延,否则它将崩溃在final GradientDrawable background = (GradientDrawable) view.getBackground();排队。
视图定义:
android:background="#FFFF0000"
android:layout_width="50dp"
android:layout_height="50dp"/>
创建并使用ObjectAnimator像这样。
final ObjectAnimator backgroundColorAnimator = ObjectAnimator.ofObject(view,
"backgroundColor",
new ArgbEvaluator(),
0xFFFFFFFF,
0xff78c5f9);backgroundColorAnimator.setDuration(300);backgroundColorAnimator.start();
您还可以使用动画Inflater从XML加载动画定义,就像XMight在Android对象动画背景色彩的布局
视图定义:
android:background="@drawable/example"
android:layout_width="50dp"
android:layout_height="50dp"/>
可绘制的定义:
<?xml version="1.0" encoding="utf-8"?>
android:color="#edf0f6"
android:width="1dp"/>
创建并使用如下所示的值动画:
final ValueAnimator valueAnimator = ValueAnimator.ofObject(new ArgbEvaluator(),
0xFFFFFFFF,
0xff78c5f9);final GradientDrawable background = (GradientDrawable) view.getBackground();
currentAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(final ValueAnimator animator) {
background.setColor((Integer) animator.getAnimatedValue());
}});currentAnimation.setDuration(300);currentAnimation.start();
视图定义:
android:background="@drawable/example"
android:layout_width="50dp"
android:layout_height="50dp"/>
可绘制的定义:
<?xml version="1.0" encoding="utf-8"?>
android:color="#edf0f6"
android:width="1dp"/>
android:color="#68aff4"
android:width="1dp"/>
使用以下可绘制的TransporttionDrawable:final TransitionDrawable background = (TransitionDrawable) view.getBackground();background.startTransition(300);
您可以通过调用.reverse()动画实例。
有一些其他的方式来做动画,但这三种可能是最常见的。我通常用的是价值动画。