android动画一(View Animation)

开一个坑,边学边总结一下学到的android动画。

这里参考并使用了部分图片与总结,来自博主** http://blog.csdn.net/yanbober **
具体博客地址在http://blog.csdn.net/yanbober/article/details/46481171

VIew Animation(视图动画)也可以称为Tween(补间)动画,用于设置View的动画,注意,视图动画是不会改变view的属性的,即便通过平移动画改变了view的显示位置,view的实际位置还是原来的位置。

视图动画可以通过

  • android代码形式
  • xml形式


    View Animation的动画形式.PNG

    使用xml形式需要在res文件夹下新建一个anim文件夹

View Animation的属性.PNG

视图动画的所有类型通用这些属性

下面介绍各个动画的不同特性

//这里是xml的实现方法
//我是用的是set方法,方便一次性显示四种方法,具体使用单种方法时就选取相应的方法
//set方法就是动画的集合,将集合内的动画一起开始
<?xml version="1.0" encoding="utf-8"?>
<!--shareInterpolator: "true"代表与set内的其他动画效果共享插值器,“false”则需要在子集中一一定义-->
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:shareInterpolator="true">
<!--alpha透明度
        fromAlpha:一开始的透明度,这些单位一般格式为float,1.0f为不透明,0.0f代表全透明
        toAlpha:动画结束后的透明度
        这里的动画效果是从全透明到不透明-->
    <alpha
        android:fromAlpha="0.0"
        android:toAlpha="1.0"
        />
<!--rotate旋转
        fromDegrees:一开始view的旋转角度,0代表不旋转,数值为正代表顺时针,负值代表逆时针
        toDegrees:动画结束后的旋转角度
        pivotX: 旋转需要根据一个点进行,这里指这个点的横坐标,用百分比形式表示。50%代表view的x轴中心,0%代表view的x轴最左边位置,百分数后p代表parent,即父控件,加上p后坐标根据父控件的百分比计算
        pivotY:旋转点的纵坐标
        这里的动画效果是根据view的x轴中心和父控件的y轴中心的坐标顺时针旋转180度-->
    <rotate
        android:fromDegrees="0"
        android:toDegrees="180"
        android:pivotX="50%"
        android:pivotY="50%p"
        />
<!--scale缩放
        fromXscale:横向的缩放倍数,大于1为放大,0到1之间为缩小
        fromYscale:纵向的缩放倍数
        toXScale:动画结束后的横向缩放倍数
        toYScale:动画结束后的纵向缩放倍数
        pivotX: 缩放需要根据一个点进行,这里指这个点的横坐标,用百分比形式表示。50%代表view的x轴中心,0%代表view的x轴最左边位置,百分数后p代表parent,即父控件,加上p后坐标根据父控件的百分比计算
        pivotY:缩放点的纵坐标
        这里的动画效果是根据view的中心点进行缩放,横向放大一倍,纵向缩小一倍-->
    <scale
        android:fromXScale="1.0"
        android:fromYScale="1.0"
        android:toXScale="2.0"
        android:toYScale="0.5"
        android:pivotY="50%"
        android:pivotX="50%"
        />
<!--scale缩放
        fromXDelta:初始的x轴位置,负值时在原来位置的左侧,正值在原来位置的右侧,平移距离根据百分数后是否有p判断,没有p表示平移距离以view的宽度的百分比进行位移,有p则表示处于父控件的百分比位置。如0%p代表在父控件最左侧
        fromYDelta:初始的y轴位置,判断方式与XDelta相同
        toXDelta:动画结束后的横向缩放倍数
        toYDelta:动画结束后的纵向缩放倍数
       -->
    <translate
        android:fromXDelta="0%p"
        android:fromYDelta="0%p"
        android:toXDelta="20%p"
        android:toYDelta="20%p"
        />
</set>

然后调用xml文件

ImageView spaceshipImage = (ImageView) findViewById(R.id.spaceshipImage);//假定一个imageView
Animation hyperspaceJumpAnimation = AnimationUtils.loadAnimation(this, R.anim.hyperspace_jump);//获取动画
spaceshipImage.startAnimation(hyperspaceJumpAnimation);//开始动画

关于android代码实现并不是特别推荐,主要是xml方式代码可读性高,也可以重复使用

animation类的方法

animation类的方法.PNG

其中setAnimationListener用于监听动画,可以设置相应的操作

View的动画方法

view的动画操作.PNG

视图动画插值器详解

系统提供的一些Interpolator.PNG

这些插值器都是使用的Interlator接口。

插值器的使用
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator"
</set>
//android代码中使用插值器
mAnimationSet.setInterlator(new 插值器的类名);
使用xml简单地自定义插值器
<!--在anim文件夹下,创建一个插值器文件,如my_interlator.xml
interlatorName表示继承的插值器的名称,attribute_name表示不同插值器可定义的不同的属性
-->
<?xml version="1.0" encoding="utf-8"?>
<InterpolatorName
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:attribute_name="value"
 />

下面是这些属性的具体定义


Interlator的一些属性(一).PNG
Interlator的一些属性(二).PNG

如果xml自定义不能满足需求,可以进阶的使用java代码进行自定义。
由于上面所有的Interpolator都实现了Interpolator接口,而Interpolator接口又继承自TimeInterpolator,TimeInterpolator接口定义了一个float getInterpolation(float input);方法,这个方法是由系统调用的,其中的参数input代表动画的时间,在0和1之间,也就是开始和

TimeInterpolator接口

package android.animation;
/**
 * 时间插值器定义了一个动画的变化率。
 * 这让动画让非线性的移动轨迹,例如加速和减速。
 */
public interface TimeInterpolator {
    /**
     * 将动画已经消耗的时间的分数映射到一个表示插值的分数。
     * 然后将插值与动画的变化值相乘来推导出当前已经过去的动画时间的动画变化量。
     * @param input  一个0到1.0表示动画当前点的值,0表示开头。1表示结尾
     * @return   插值。它的值可以大于1来超出目标值,也小于0来空破底线。
     */
    float getInterpolation(float input);
}

Interpolator接口

package android.view.animation;
import android.animation.TimeInterpolator;
/**
 * 一个定义动画变化率的插值器。
 * 它允许对基本的(如透明,缩放,平移,旋转)进行加速,减速,重复等动画效果
 */
public interface Interpolator extends TimeInterpolator {
    // A new interface, TimeInterpolator, was introduced for the new android.animation
    // package. This older Interpolator interface extends TimeInterpolator so that users of
    // the new Animator-based animations can use either the old Interpolator implementations or
    // new classes that implement TimeInterpolator directly.
}

而自定义插值器主要就是重写getInterlation()方法。这里完全可以查看系统提供的插值器代码进行学习。

这一部分就先写到这里,如果有补充,会慢慢更新的。

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

推荐阅读更多精彩内容

  • 1 背景 不能只分析源码呀,分析的同时也要整理归纳基础知识,刚好有人微博私信让全面说说Android的动画,所以今...
    未聞椛洺阅读 2,701评论 0 10
  • 转载一篇高质量博文,原地址请戳这里转载下来方便今后查看。1 背景不能只分析源码呀,分析的同时也要整理归纳基础知识,...
    Elder阅读 1,940评论 0 24
  • 翻老同學的朋友圈下載了簡書。有時就是這樣,遇到某個人,發生某些變化。一如小學同窗一年,成為終生好友,也因此遠...
    一抹水藍阅读 113评论 0 0
  • 我出生于太湖之滨的江苏无锡,“嫁”给长春既是上天旨意,也是三生缘分。取江南出生地,媳妇芳名中,便有了江南北国的特殊...
    雨燕江南阅读 407评论 3 16
  • 1. 热播剧《楚乔传》中,女主角有一句很霸气的台词—— “等到有一天,当我不用再仰视你的时候,我再告诉你我的名字。...
    苏林深阅读 1,382评论 9 37