属性动画 小总结

Animator小总结

  • 一般关于动画都是属性动画了,补间动画的话就不要使用了原因是此动画仅仅只是改变了View的视图位置,而关于事件的响应位置没有变化,就造成点击动画后的位置是不会有任何事件产生的。

  • 所谓属性动画可不仅仅适用于View 对象,其他对象也同样可以用。只要适用的对象有用的属性的get ,set 方法就好,只是肯定屏幕不会有动画,但开始值是一定会过渡到结束值得。

  • 常用于View的动画属性动画有四种: alpha (淡入淡出效果),rotation(旋转效果) ,translation(平移动画) , scale (缩放动画) .

  • 属性动画类有 ValueAnimator, ObjectAnimator, AnimatorSet . (其中ValueAnimator 类和ObjectAnimator 类 获得对象的方式是单例). 用于赋值给属性的可变参数部分呢,两两成对(开始值---结束值).如果只传入一个值表示结束值,开始值的话会自动调用 属性的get方法获取.

    • ValueAnimator 类的对象并不是直接作用于 对象的属性, 仅仅是控制下列方法的可变参数 的部分变化.

参数一TypeEvaluator(估值器)类对象,参数二 是一个可变参数列表 Object对象:
java ValueAnimator . ofObject(TypeEvaluator evaluator, Object... values) ;
参数二 是一个可变参数列表 float对象.

```java

ValueAnimator. ofFloat(float... values) ;
```
参数一 是一个可变参数列表 int对象.

```java

ValueAnimator . ofInt(int... values);
```

  • ObjectAnimator 类 就是可以直接对操作对象的属性赋值 . 常见方法有下列:

参数一为目标对象(即属性动画的目标对象) , 参数二为属性名 , 参数三为可变参数 float 值可传入多个(即作用于属性的值).
java ObjectAnimator.ofFloat(Object target, String propertyName, float... values);
参数一为目标对象,参数二为属性名, 参数三为可变参数 int值.

ObjectAnimator.ofInt(Object target, String propertyName, int... values)

参数一为目标对象,参数二为属性名,参数三为TyepEvaluator对象(估值器). 参数四为可变参数 object对象.

ObjectAnimator.ofObject(Object target, String propertyName, TypeEvaluator evaluator, Object... values) 

--

  • AnimatorSet类 ,主要用于设置动画的集合,因为有时会需要几种动画效果一起执行,Object 对象更多的只是单一动画.
```java
after(Animator  anim); //  将现有的动画插入到传入的动画之后执行.     
after(long delay);//将现有的动画延迟指定毫秒执行.
before(Animator anim);//将现有的动画插入到传入动画之前执行.
with(Animator anim); //将现有的动画和传入动画一起执行.
```
AnimatorSet 对象 是以Build 链的方式 实现功能. 但是系统比如    animSet.play(anim1).with(anim2).before(anim3).before(anim5);  是不会按此顺序执行滴。

animSet.play(anim1).with(anim2); 以这种方法多写几行.

--

  • 三种属性动画类的写法:

setDuration(long duration); //用于动画的持续时间
setInterpolator(TimeInterpolator value);//用于设置插值器,即动画的运动方式.
start(); //启动动画,这三个方法对于三种属性动画没有任何区别.

ObjectAnimator rotationA = ObjectAnimator.ofFloat(coinImage,"rotationY",0,360f).setDuration(5000);
rotationA.start( );


    ```java
ValueAnimator  value = ValueAnimator.ofFloat(0,1).setDuration(1000);
rotation.start( );
ObjectAnimator moveIn = ObjectAnimator.ofFloat(textview, "translationX", -500f, 0f);  
ObjectAnimator rotate = ObjectAnimator.ofFloat(textview, "rotation", 0f, 360f);  
ObjectAnimator fadeInOut = ObjectAnimator.ofFloat(textview, "alpha", 1f, 0f, 1f);  
AnimatorSet animSet = new AnimatorSet().setDuration(5000);  
animSet.play(rotate).with(fadeInOut).after(moveIn);  //此处动画执行顺序为先移动,后旋转和淡入淡出一起播放.
animSet.start(); 
  • 属性动画的监听器

    其中addListener(Animator.AnimatorListener listener) 方法对于三种属性动画都是通用的.addUpdateListener(ValueAnimator.AnimatorUpdateListener listener) 此方法能用的就是ValueAnimator 和ObjectAnimator ,因AnimatorSet 是直接继承 Animator 类 所以呢并不能设置此监听器. addPauseListener(Animator.AnimatorPauseListener listener)

public interface AnimatorPauseListener {
void onAnimationPause(Animator var1); //在属性动画暂停的时候回调;

void onAnimationResume(Animator var1); //在属性动画重新开始的时候回调;

}


    ```java
public interface AnimatorUpdateListener {
  void onAnimationUpdate(ValueAnimator var1);//在属性动画的属性值变化是回调。
}
 public interface AnimatorListener {
     void onAnimationStart(Animator var1);  //在属性动画开始时回调;

     void onAnimationEnd(Animator var1);  //在属性动画结束时回调;

     void onAnimationCancel(Animator var1); //在属性动画被撤销是回调

     void onAnimationRepeat(Animator var1); //在属性动画重复时回调
 }

有时也许并不需要这么多接口,而只想要其中一到两个,那么 AnimatorListenerAdapter 类就能派上用处了。 此适配器主要导入 AnimatorPauseListener 和 AnimatorListener 接口 .

  • XML 编写动画 (复用性强)

通过XML 编写动画文件呢,首先需要在res目录下新建animator文件夹,并把所有的动画资源文件都放置到此文件夹下。

< animator> 对应Valueanimator;
< objectAnimator> 对应ObjectAnimator;
< set> 对应AnimatorSet;

使用< set > 标签呢 ,主要注意android:orderring 属性 其中 together 值 表示动画一起执行, sequentially 值(表示动画顺序执行)。 通过对set标签的嵌套呢都是可以实现代码所呢实现的动画的.通过使用AnimatorInflater加载动画资源文件.

rotaion(旋转) , translation (移动) ,scale(缩放) .都是可以设置是否依据X 轴还是Y轴的。

  • View 对象 的animate( )方法

在android 3.1 系统后呢, View 类新增了一个方法animate( )方法(返回一个ViewPropertyAnimator对象),用于view 对象很方便的实现属性动画的效果,也更符合面向对象.

view.animate( ).alpha(0f);//这样就是淡入淡出动画了. ViewPropertyAnimator 是支持链式用法的。这里并不需要显示的start( ) 方法来启动动画,其内部已隐式完成了. 同样呢调用setDuration(int 。。) 方法来设置动画时间.


这是张鸿洋的动画总结连接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • Animation Animation类是所有动画(scale、alpha、translate、rotate)的基...
    四月一号阅读 1,899评论 0 10
  • 写的非常好,强烈推荐给大家 转载请注明出处:http://blog.csdn.net/guolin_blog/ar...
    天天大保建阅读 775评论 0 1
  • 在手机上去实现一些动画效果算是件比较炫酷的事情,因此Android系统在一开始的时候就给我们提供了两种实现动画效果...
    Ten_Minutes阅读 3,870评论 3 11
  • 今天我要演讲的题目是:改变 一个人想要改变生活中的一个习惯非常的困难,但是只要他想要改变的话,就可以将自己自身的坏...
    百合花中哥哥阅读 518评论 0 0