最近用到了ScaleAnimation来实现图片放大需求,今天就把使用过程中学习的一些东西总结记录一下,希望能对大家有所帮助。

- ScaleAnimation是 Android官方提供的动画类Animation的子类

Animation类是一个抽象类,我们通常会使用它的四个子类AlphaAnimationRotateAnimationScaleAnimationTranslateAnimation,他们分别可以实现渐变动画旋转动画平移动画缩放动画 功能,当然我们今天的主角就是缩放动画 ScaleAnimation

Android中的坐标

要用到ScaleAnimation,我们最好先了解Android的坐标,当然这并不是我们这篇文章的重点,所以我就在这里放一篇我学习坐标时看的博客,供大家参考一下,不具体展开讲解了,想要深入了解的朋友可以去找找别的相关博客。

https://blog.csdn.net/lvxiangan/article/details/19971509

ScaleAnimation的属性

我们先从源码来看看ScaleAnimation的诸多属性,mFromX、mToX、mFromY、mToY和mPivotXType、mPivotXValue、mPivotYType、mPivotYValue这八个属性可以通过XML或代码调用构造方法来注入。

public class ScaleAnimation extends Animation {    private float mFromX;   //动画开始前X坐标比例    private float mToX;//动画开始后X坐标比例    private float mFromY;//动画开始前Y坐标比例    private float mToY;//动画开始后Y坐标比例        //动画开始前X坐标类型    private int mFromXType = TypedValue.TYPE_NULL;    //动画开始后X坐标类型    private int mToXType = TypedValue.TYPE_NULL;    //动画开始前Y坐标类型    private int mFromYType = TypedValue.TYPE_NULL;    //动画开始后Y坐标类型    private int mToYType = TypedValue.TYPE_NULL;      private int mPivotXType = ABSOLUTE; //缩放中心点的X坐标类型    private int mPivotYType = ABSOLUTE;//缩放中心点的Y坐标类型    private float mPivotXValue = 0.0f;//缩放中心点的X坐标比例    private float mPivotYValue = 0.0f;//缩放中心点的Y坐标比例    private float mPivotX;    private float mPivotY;}
  • 接下来,我们尝试一下XML方式的属性注入
<?xml version="1.0" encoding="utf-8"?>  <scale xmlns:android="http://schemas.android.com/apk/res/android"      android:fromXScale="1.0"  //起始x尺寸比例,示例为1.0即原比例放大      android:toXScale="1.4"//最终x尺寸比例,示例为1.4即放大为原来的1.4倍    android:fromYScale="1.0"//起始y尺寸比例,,示例为1.0即原比例放大    android:toYScale="1.4"//最终y尺寸比例,示例为1.4即放大为原来的1.4倍        android:pivotX="50%"//缩放起点x轴坐标    android:pivotY="50%"        //缩放起点Y轴坐标    android:duration="700"     //动画持续时间,单位是毫秒,示例为动画持续700ms    android:fillAfter="true"  //动画结束后,保持结束时的状态    android:fillBefore="true"  //用于确定动画开始时,View的动画属性值;    android:fillEnabled="true"//用来控制fillBefore属性是否有效    android:repeatCount="5"//重复次数,取值为-1时无限重复,默认动画执行一次    android:repeatMode ="reverse"//重复模式,有reverse和restart两个值,前者为倒序回放,后者为重新开始            />

对代码中比较复杂的几个属性,再详细讲一下:

  • pivotX:取值可以是数值(50)百分数(50%)百分数p(50%p),当取值为数值时,缩放起点为View左上角坐标加具体数值像素;当取值为百分数时,表示在当前View左上角坐标,加上View宽度的具体百分比;当取值为百分数p时,表示在View左上角坐标加上父控件宽度的具体百分比。

  • pivotY:用法与pivotX相同。

  • fillBefore:代码注释中所说的动画开始不是指的调startAnimation方法,而是界面中动画真正开始动的时候。从调用startAnimation到动画真正开始,中间有一个startOffset阶段,若fillBeforetrue,则在startOffset阶段时,将动画属性设置为初始值,为false,则为View本身的初始值。

  • fillEnabled:用来控制fillBefore属性是否有效,若为true,则fillBefore生效;若为false则不管设置fillBefore为true还是false,都不起作用。但是,划重点了,当fillEnabled为false时,我们假设fillBefore为true。也就是说,当 fillEnabled为false时,不管fillBefore是什么值,在startOffset阶段都将初始值设置为动画属性的初始值。

在使用代码调用构造方法来实现属性注入的方式时,ScaleAnimation给出了两种传参个数不同的构造方法,我们来一个一个介绍。

  • 首先是传入参数较多的那个,传入了八个参数,fromX、toX、fromY、toY和pivotXType、pivotXValue、pivotYType、pivotYValue

    虽然这些参数上文已经有过说明,为了阅读方便,再次介绍一下。

    • fromX:动画开始前X坐标比例
    • toX:动画开始后X坐标的比例
    • fromY:动画开始前Y坐标的比例
    • toY:动画开始后Y坐标的比例
    • pivotXType:缩放中心点的X坐标类型
    • pivotXValue:缩放中心点的X坐标比例
    • pivotYType:缩放中心点的Y坐标类型
    • pivotYValue:缩放中心点的Y坐标比例
public class Test{private void test(){....//示例传参实现的是,以控件中心为缩放点,从原图即1.0倍放大到1.4倍ScaleAnimation animation = new ScaleAnimation(1.0F, 1.4F, 1.0F, 1.4F, 1, 0.5F, 1, 0.5F);}}
  • 接下来实现的是传入参数较少的构造方法,传入六个参数,fromX、toX、fromY、toY和pivotX、pivotY,关于参数已介绍多次,不再赘述。
public class Test{private void test(){....//示例传参实现的是,以控件中心为缩放点,从1.0倍缩小到0.5倍,即原图的二分之一,不设置缩放点类型,默认坐标原点以控件为准ScaleAnimation animation = new ScaleAnimation(1.0F, 0.5F, 1.0F, 0.5F, 0.5F, 0.5F);}}

ScaleAnimation的实际使用

上面给出的例子只是完成了属性的注入,真正要使用ScaleAnimation,我们还需要设置一些参数,且XML方式中,我们还没有进行对象的实例化,下面就来具体操作一下吧。

  • 在XML中,我们已经完成了所需要的全部属性设定,所以在代码中我们只要传入我们创建的XML文件来实例化对象之后,就可以启动动画啦。
public class Test{private void test(){....//注意这里传入的的两个参数,要根据自己的类名和文件名切换ScaleAnimation animation = AnimationUtils.loadAnimation(AnimDemoActivity.this,R.anim.scale;//让执行动画的view对象调用启动方法view.startAnimation(scaleAnimation);}
  • 重载的两种不同构造方法并不会影响我们之后的代码书写,所以只给出一份代码示例,请注意,构造对象时传入的参数并不是我们能设置的全部属性,可以对比一下前面的XML文件内容。
public class Test{private void test(){....//这里是上文用过的实例化对象示例,不再介绍ScaleAnimation animation = new ScaleAnimation(1.0F, 1.4F, 1.0F, 1.4F, 1, 0.5F, 1, 0.5F);animation.setDuration(200);//动画持续时间,单位是毫秒,示例为动画持续200msanimation.setFillAfter(true);//动画结束后,保持结束时的状态animation.setFillBefore(true);//用于确定动画开始时,View的动画属性值;        animation.setFillEnabled(true);//用来控制fillBefore属性是否有效        animation.setRepeatCount(1);//重复次数,取值为-1时无限重复,默认动画执行一次        animation.setRepeatMode(Animation.REVERSE);//重复模式,有reverse和restart两个值,前者为倒序回放,后者为重新开始                //让执行动画的view对象调用启动方法        view.startAnimation(scaleAnimation);}}

其实除了上文代码和XML文件中设置的属性之外,ScaleAnimation还提供了一些别的可以功能属性,比如setStartTime() 方法,设置启动的时间,传入一个Long类型的参数,因为博主我也没有用过,想要了解的读者就自己去源码或者别的博客里看吧。

Animation与Animator

因为在选择实现方式时也曾了解过Animator的用法,感觉挺有趣的,所以最后的最后,我们再来看一下这个已经不算新来的新伙计,当然主要还是聊下他与Animation的不同啦,具体的介绍那可说来话长,就不说了。

  1. Animation是Android发行之时就存在的动画框架,而animator是在之后的版本才新加入的,在兼容性上,Animation肯定是优于后来者的。
  2. Animation动画并不实际改变view的坐标值,只是在视图上实现动画,而Animator则会改变view的坐标值,这点我深有体会,在实现图片放大需求时,我有试过监听Animation动画实现前后view的坐标值,然后发现view的坐标值并不会发生变化,同时放大的图片还覆盖了下方的文字,而文字在layout的布局设置了相对图片的below属性。
  3. Animation只能对view执行动画,而Animator功能更加强大,他不仅可以针对 view执行动画, 还可以对所有的 Object 执行动画。

当然在具体选择使用Animation还是Animator时就要考虑实际需求来决定啦,功能强大的兼容性和执行效率上不一定好,Animation和Animator各有其天地。

更多相关文章

  1. [WebView学习之二]:使用Web Apps 支持不同分辨率屏
  2. android BitmapFactory.Options参数介绍
  3. Android程序开始的等待动画或LOGO
  4. android 利用FloatActionButton悬浮按钮实现扇形折叠与隐藏
  5. android 中FragmentActivity中模拟返回键返回上一个Activity效果
  6. android ViewPager动画的实现原理及效果
  7. Android(安卓)Animation动画效果
  8. android - 利用View自身的setAnimation来实现动画。
  9. Android(安卓)ObjectAnimator基础用法

随机推荐

  1. Android模拟器环境中安装和删除应用程序
  2. 一定是我打开的姿势不对——Android下使
  3. 布局
  4. Android导入项目时出现红色感叹号
  5. Android刷Recovery
  6. android sdk API level对应关系及下载地
  7. 关于android应用程序的入口
  8. 关于android的各种disk images
  9. Android中的全局变量
  10. android 2.android 系统架构与应用程序目