Android 属性动画ValueAnimator与插值器详解
作者:lqh 时间:2023-04-12 19:05:33
Android 属性动画ValueAnimator与插值器详解
一、ValueAnimator详解:
ValueAnimator是整个动画的核心,ObjectAnimator即是继承自ValueAnimator来实现。
ValueAnimator更像是一个数值发生器,用来产生具有一定规律的数字,从而让调动者来控制动画的实现过程。
1、ValueAnimator的使用:
ValueAnimator valueAnimator = ValueAnimator.ofFloat(0, 100);
valueAnimator.setDuration(1000).start();
//可以设置插值器来设置动画的类型,比如是“加速”,"减速",还是"先加速后减速"等,下面为使用系统的减速插值器
//参考网址:http://blog.sina.com.cn/s/blog_6e519585010157zt.html
valueAnimator.setInterpolator(new DecelerateInterpolator());
final int baseWidth = animatorBt.getWidth();
//valueAnimator会在1000毫秒内产生0到100的数值,而我们可以在回调中通过animation.getAnimatedValue()得到此数值,然后进行自定义动画设置
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
Float value = (Float) animation.getAnimatedValue();
LogUtils.showLog("value为"+value);
//使用这个value
//1.改变距离
animatorBt.setTranslationX(value * 5);
//2.改变透明度
animatorBt.setAlpha(1 - (value) / 200);
//3.增加button的宽度,这个是在ObjectAnimator中无法直接设置的
ViewGroup.LayoutParams params = animatorBt.getLayoutParams();
params.width = (int) (baseWidth + value);
LogUtils.showLog("宽度为"+params.width);
//当这个view的布局属性改变了之后要调用这个方法
animatorBt.requestLayout();
}
});
}
}, 1000);
2、停止ValueAnimator动画:
可以调用ValueAnimator对象的cancel()方法或者end()方法。 首先调用上述两种方法都会停止动画,不过区别就在于
1、调用cancel()后,ValueAnimator会立即停止,不会再回调了。
2、调用end()后,ValueAnimator会直接回调此动画结束状态的那个值,即,如果调用了end(),动画会直接停止到最后。
二、Android插值器Interpolator的使用:
插值器可以实现动画实现衰减效果,比如"逐渐减小",“逐渐增大”,“先加速后减速”
下面是几种常用的插值器:
1、AccelerateInterpolator:动画从开始到结束,变化率是一个加速的过程。
2、DecelerateInterpolator:动画从开始到结束,变化率是一个减速的过程。
3、CycleInterpolator:动画从开始到结束,变化率是循环给定次数的正弦曲线。
4、AccelerateDecelerateInterpolator:动画从开始到结束,变化率是先加速后减速的过程。
5、LinearInterpolator:动画从开始到结束,变化率是线性变化。
1、使用方法为:
//设置一个减速的插值器
valueAnimator.setInterpolator(new DecelerateInterpolator());
ValueAnimator的原理可以去看看其源码:
void animateValue(float fraction) {
//fraction即为线性的从0-1.0的大小,即假如从200-500,200ms完成,在200ms内,fraction是从0-1.0f来变化更新的,跟具体的要变化的数字没有关系,也可以理解为,fraction为坐标轴上的x值
//下面即为将x值传给自己的插值器
fraction = mInterpolator.getInterpolation(fraction);
mCurrentFraction = fraction;
int numValues = mValues.length;
for (int i = 0; i < numValues; ++i) {
mValues[i].calculateValue(fraction);
}
//此为将最后的数据回调回去
if (mUpdateListeners != null) {
int numListeners = mUpdateListeners.size();
for (int i = 0; i < numListeners; ++i) {
mUpdateListeners.get(i).onAnimationUpdate(this);
}
}
}
2、自定义插值器:
//所以,要使用自定义的插值器的话,需要继承BaseInterpolator抽象类,然后实现里面的抽象方法:
float getInterpolation(float input );//input是传入的从0-1.0f的x值,而我们就是返回0-1.0f的y值。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://blog.csdn.net/happyheng/article/details/51756043