android 背景色动画,Android上视图背景色的动态变化

根据视图如何获得其背景色和如何获得目标颜色,有几种不同的方法可以做到这一点。

用对象动画如果:视图的背景色定义为

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()动画实例。

有一些其他的方式来做动画,但这三种可能是最常见的。我通常用的是价值动画。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值