属性动画跟早些的补间动画最大的差别应该是补间动画只是个绘画的展示效果,duang duang duang都是特技,是假的,属性动画是view本身的属性真的跟着动画改变的,是真的。
ValueAnimator 使用姿势:
ValueAnimator valueAnimator = ValueAnimator.ofFloat(0,1.0f);
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
Float animatedValue = (Float) animation.getAnimatedValue();
getGuideHand().setAlpha(animatedValue);
}
});
valueAnimator.addListener(new Animator.AnimatorListener() {
@Override
public void onAnimationStart(Animator animation) {
}
@Override
public void onAnimationEnd(Animator animation) {
}
@Override
public void onAnimationCancel(Animator animation) {
}
@Override
public void onAnimationRepeat(Animator animation) {
}
});
valueAnimator.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationStart(Animator animation) {
}
});
ObjectAnimator.ofFloat(tv, "Alpha", 0f, 1f).start();
嗯 没错,就只有这一句实现了上述ValueAnimator的透明度动画。。。
不过还是有几个注意点,参数二 属性值不需要关注首字母大小写问题,但是动画对象必须要有相对应的set方法,(如果valueFrom或者valueTo有为null的,那get方法也必须要有)
ObjectAnimator.ofFloat(iv_red_package, "ScaleX", 0, 1);
ObjectAnimator.ofFloat(iv_top, "translationY", iv_top.getMeasuredHeight(), 0);
ObjectAnimator.ofFloat(iv_halo, "Rotation", 0, 360);
AnimatorSet animatorSet = new AnimatorSet();
animatorSet.play(anim1).before(anim2).before(anim3);
animatorSet.start();
很好理解,先放anim1,再放anim2,再放anim3,很简单对不对。
错!正确的结果是anim1完后anim2,anim3同时播放。啪啪啪,敲重点。play方法会创建一个Builder,同时,play方法传入的动画对象会成为一个节点,之后的所有不管是before,after还是with,都会以这个节点作为目标节点。所以,优雅的写法是一对一对得写:
AnimatorSet animatorSet = new AnimatorSet();
animatorSet.play(anim1).before(anim2);
animatorSet.play(anim2).before(anim3);