Android动画之补间动画(Tween Animation)基础学习

Android动画之补间动画(Tween Animation)基础学习,第1张

概述前言之前说过了在Android中,动画Animation的实现有两种方式:TweenAnimation(渐变动画)和FrameAnimation(帧动画)。渐变动画是通过对场景里的对象不断做图像变换(平移、缩放、旋转等)产生动画效果。帧动画则是

前言

之前说过了在AndroID中,动画Animation的实现有两种方式:Tween Animation(渐变动画)和Frame Animation(帧动画)。渐变动画是通过对场景里的对象不断做图像变换(平移、缩放、旋转等)产生动画效果。帧动画则是通过顺序播放事先准备好的图像来产生动画效果,和电影类似。

小编也和大家分享了逐帧动画的基础知识,下面我们就来学习下AndroID中逐帧动画的基础知识。

原理 : 给出开始和结束两个关键帧,两个关键帧之间的插补帧是由计算机自动运算而得到的。

分类 : AlphaAnimation(透明度) ScaleAnimation(缩放) TranslateAnimation(位移) RotateAnimation (旋转) AnimationSet(组合)

方式 :

1.在代码中new

2.在anim文件夹下定义动画xml资源

效果

代码

第一步 :准备动画资源

目录

<?xml version="1.0" enCoding="utf-8"?><Alpha xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:duration="2000" androID:fromAlpha="1.0" androID:interpolator="@androID:anim/linear_interpolator" androID:toAlpha="0.3"></Alpha>
<?xml version="1.0" enCoding="utf-8"?><rotate xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:interpolator="@androID:interpolator/linear" androID:repeatCount="infinite" androID:repeatMode="reverse" androID:duration="2000" androID:fromdegrees="0" androID:todegrees="1080"> androID:pivotX="50%" androID:pivotY="50%"</rotate>
<?xml version="1.0" enCoding="utf-8"?><scale xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:interpolator="@androID:anim/linear_interpolator" androID:duration="2000" androID:fillAfter="true" androID:fromXScale="1.0" androID:fromYScale="1.0" androID:pivotX="50%" androID:pivotY="50%" androID:toXScale="0.3" androID:toYScale="0.3"></scale>
<?xml version="1.0" enCoding="utf-8"?><translate xmlns:androID="http://schemas.androID.com/apk/res/androID"  androID:interpolator="@androID:anim/linear_interpolator"  androID:duration="2000"  androID:fromXDelta="10"  androID:fromYDelta="10"  androID:toXDelta="300"  androID:toYDelta="300"></translate>
<?xml version="1.0" enCoding="utf-8"?><set xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:interpolator="@androID:anim/linear_interpolator" androID:duration="2000"> <Alpha androID:fromAlpha="0.3"  androID:toAlpha="1.0"/> <rotate androID:fromdegrees="0"  androID:todegrees="360"  androID:pivotX="0"  androID:pivotY="0"  androID:repeatMode="restart"  androID:repeatCount="infinite"/></set>

第二步 :activity_main.xml ( 略 )

第三步 :MainActivity.java

package com.lyp.anim;import androID.support.v7.app.AppCompatActivity;import androID.os.Bundle;import androID.vIEw.VIEw;import androID.vIEw.animation.Animation;import androID.vIEw.animation.AnimationUtils;import androID.Widget.button;import androID.Widget.ImageVIEw;public class MainActivity extends AppCompatActivity implements VIEw.OnClickListener{ private button btnScale; private button btnRotate; private button btnTranslate; private button btnAlpha; private button btnAll; private ImageVIEw mImage; @OverrIDe protected voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentVIEw(R.layout.activity_main); initVIEw(); } private voID initVIEw() { btnScale= (button) findVIEwByID(R.ID.btn_scale); btnRotate= (button) findVIEwByID(R.ID.btn_rotate); btnTranslate= (button) findVIEwByID(R.ID.btn_translate); btnAlpha= (button) findVIEwByID(R.ID.btn_Alpha); btnAll= (button) findVIEwByID(R.ID.btn_all); mImage= (ImageVIEw) findVIEwByID(R.ID.image); btnScale.setonClickListener(this); btnRotate.setonClickListener(this); btnTranslate.setonClickListener(this); btnAlpha.setonClickListener(this); btnAll.setonClickListener(this); } @OverrIDe public voID onClick(VIEw v) { switch (v.getID()){  case R.ID.btn_scale:  //加载缩放动画  Animation scale = AnimationUtils.loadAnimation(this,R.anim.scale);  scale.setFillAfter(true); //保留动画结束状态,在xml文件中设置无效!!  mImage.startAnimation(scale);  break;  case R.ID.btn_rotate:  //加载旋转动画  Animation rotate = AnimationUtils.loadAnimation(this,R.anim.rotate);  mImage.startAnimation(rotate);  break;  case R.ID.btn_translate:  //加载位移动画  Animation translate = AnimationUtils.loadAnimation(this,R.anim.translate);  mImage.startAnimation(translate);  break;  case R.ID.btn_Alpha:  //加载透明度渐变动画  Animation Alpha = AnimationUtils.loadAnimation(this,R.anim.Alpha);  mImage.startAnimation(Alpha);  break;  case R.ID.btn_all:  //加载组合动画  Animation all = AnimationUtils.loadAnimation(this,R.anim.all);  mImage.startAnimation(all);  break; } }}

总结

以上AndroID中补间动画(Tween Animation)基础的全部内容了,动画Animation实现的两种方式小编现在已经都给大家分享了,希望能对各位AndroID开发者们有所帮助,如果有疑问大家可以留言交流。

总结

以上是内存溢出为你收集整理的Android动画之补间动画(Tween Animation)基础学习全部内容,希望文章能够帮你解决Android动画之补间动画(Tween Animation)基础学习所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1148066.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存