博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android之属性动画(二)
阅读量:7171 次
发布时间:2019-06-29

本文共 2638 字,大约阅读时间需要 8 分钟。

  上一篇文章(链接:  ),我们对属性动画有了简单的认识,并实际动手使用ObjectAnimator、AnimatorSet完了一个简单的例子,本次继续对剩余内容进行学习。

  首先让我们先来了解一下动画是如何计算的呢?从官方文档上我们可以看到下面这张图:

 

  图中描述了动画过程中相互工作的主要类,其中ValueAnimator对象可以记录动画时间轨迹。ValueAnimator中含有一个TimeInterpo;ator,此属性用于描述动画的时间插值;含有一个TypeEvaluator,此属性用于指定动画属性值是如何被计算出来的。

  创建一个ValueAnimator并启动动画后,ValueAnimator在动画运行期间会计算一个0到1的分数,这个分数用于表示整个动画运行的百分比。当ValueAnimator计算好一个运行分数后,会调用当前设置的TimeInterpolator去计算插值分数;插值分数计算好后,ValueAnimator调用TypeEvaluator根据插值分数计算属性的值。

  这里的ValueAnmiator就是我们在上一章中使用的ObjectAnimator的父类,需要注意的是ValueAnimator不会直接操作一个对象或者属性,也就意味着我们如果想使用ValueAnimator完成动画,就必须为ValueAnimator添加一个监听器:

ValueAnimator animator = ValueAnimator.ofFloat(0.0f, 360f);                animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {                    @Override                    public void onAnimationUpdate(ValueAnimator animation) {                        //当前动画进度                        float curValue = (Float) animation.getAnimatedValue();                        imageView.setRotationX(curValue);                    }                });                animator.setDuration(4000);                animator.setInterpolator(new DecelerateInterpolator());                animator.start();

  效果图:

  当ValueAnimator的ofInt、ofFloat不能满足需求是,我们可以使用ofObject方法,这时候需要继承TypeEvaluaot<T>自定义即可。

  除了AnimatorUpdateListener之外,属性动画框架为我们提供了Animator.AnimatorListener监听器:

  Android提供了一个此监听器的默认实现AnimatorListenerAdapter,我们只需要继承此类即可,参考代码如下:

animator.addListener(new AnimatorListenerAdapter() {                    @Override                    public void onAnimationEnd(Animator animation) {                        PropertyValuesHolder holderX =PropertyValuesHolder.ofFloat("translationX",0f,260f);                        PropertyValuesHolder holderY=PropertyValuesHolder.ofFloat("translationY",0f,260f);                        ObjectAnimator.ofPropertyValuesHolder(imageView,holderX,holderY)                                .setDuration(4000)                                .start();                    }                });

  属性动画中常用的属性有:

TranslationX、TranslatioinY:相对于布局容器的左边和上边的坐标值

Rotation、rotationX、rotationY:旋转属性

scalX、scalY:缩放属性

pivotX、pivotY:设置旋转、缩放时的中心点

x、y:坐标

alpha:透明度

  和view动画一样,除了使用java代码完成动画外,我们同样可以使用xml文档来编写属性动画。要注意的是xml文件的目录不再是anim,而是要在res下新建一个animator文件夹用于存放。

  Xml代码如下:

  在java中使用:

AnimatorSet animatorSet = (AnimatorSet)AnimatorInflater.loadAnimator(this,R.animator.myanimator);                animatorSet.setTarget(imageView);                animatorSet.start();

 

  想要深入学习的同学,可以点击,查看更多详细内容!

 

作者:
出处:
 
本文版权归和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
 
你可能感兴趣的文章
Android做按住显密码的View
查看>>
静态路由原理及实验
查看>>
Android——自定义Dialog
查看>>
编码原理(附二)----二值化
查看>>
技能大赛规程
查看>>
涓栫晫鐢靛奖绠€鍙测€?
查看>>
Redis入门系列之队列和发布订阅模式
查看>>
Ceph学习笔记
查看>>
unity自带的水
查看>>
LVS搭建过程中需要用到的命令-- ipvsadm
查看>>
【No.9 内存泄漏了么】
查看>>
想成为一名DBA 至少要具备哪些技术
查看>>
CentOS 编译安装php5.5, 并配制支持apach,nignx核心代码
查看>>
第3章 初探HTML
查看>>
基于S/MIME V2标准的加密和解密的控件software IP*Works! S/MIME
查看>>
mysql 备份数据库脚本
查看>>
Linux文件系统上的特殊权限
查看>>
IBM携手红帽将助力企业加快虚拟化步伐
查看>>
8.C++引用
查看>>
利用imgateaselect插件实现前端页面图片截取功能
查看>>