`

Android动画开发——Animation动画效果

 
阅读更多
Android动画开发——Animation动画效果
Android开发, 动画效果
动画类型

Android的animation由四种类型组成

XML中
alpha
渐变透明度动画效果

scale
渐变尺寸伸缩动画效果

translate
画面转换位置移动动画效果

rotate
画面转移旋转动画效果



JavaCode中
AlphaAnimation
渐变透明度动画效果

ScaleAnimation
渐变尺寸伸缩动画效果

TranslateAnimation
画面转换位置移动动画效果

RotateAnimation
画面转移旋转动画效果


Android动画模式

Animation主要有两种动画模式:
一种是tweened animation(渐变动画)
XML中
JavaCode

alpha
AlphaAnimation

scale
ScaleAnimation



一种是frame by frame(画面转换动画)
XML中
JavaCode

translate
TranslateAnimation

rotate
RotateAnimation




如何在XML文件中定义动画

① 打开Eclipse,新建Android工程
② 在res目录中新建anim文件夹
③ 在anim目录中新建一个myanim.xml(注意文件名小写)
④ 加入XML的动画代码
<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">

  <alpha/>

  <scale/>

  <translate/>

  <rotate/>

</set>
复制代码

Android动画解析--XML

<alpha>

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android" >

<alpha

android:fromAlpha="0.1"

android:toAlpha="1.0"

android:duration="3000"

/>

<!-- 透明度控制动画效果 alpha

        浮点型值:

            fromAlpha 属性为动画起始时透明度

            toAlpha   属性为动画结束时透明度

            说明:

                0.0表示完全透明

                1.0表示完全不透明

            以上值取0.0-1.0之间的float数据类型的数字



        长整型值:

            duration  属性为动画持续时间

            说明:    

                时间以毫秒为单位

-->

</set>
复制代码       

<scale>
<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">

   <scale 

          android:interpolator=

                     "@android:anim/accelerate_decelerate_interpolator"

          android:fromXScale="0.0"

          android:toXScale="1.4"

          android:fromYScale="0.0"

          android:toYScale="1.4"

          android:pivotX="50%"

          android:pivotY="50%"

          android:fillAfter="false"

          android:duration="700" />

</set>

<!-- 尺寸伸缩动画效果 scale

       属性:interpolator 指定一个动画的插入器

        在我试验过程中,使用android.res.anim中的资源时候发现

        有三种动画插入器:

            accelerate_decelerate_interpolator  加速-减速 动画插入器

            accelerate_interpolator        加速-动画插入器

            decelerate_interpolator        减速- 动画插入器

        其他的属于特定的动画效果

      浮点型值:

        

            fromXScale 属性为动画起始时 X坐标上的伸缩尺寸   

            toXScale   属性为动画结束时 X坐标上的伸缩尺寸    

       

            fromYScale 属性为动画起始时Y坐标上的伸缩尺寸   

            toYScale   属性为动画结束时Y坐标上的伸缩尺寸   

       

            说明:

                 以上四种属性值   

   

                    0.0表示收缩到没有

                    1.0表示正常无伸缩    

                    值小于1.0表示收缩 

                    值大于1.0表示放大

       

            pivotX     属性为动画相对于物件的X坐标的开始位置

            pivotY     属性为动画相对于物件的Y坐标的开始位置

       

            说明:

                    以上两个属性值 从0%-100%中取值

                    50%为物件的X或Y方向坐标上的中点位置

       

        长整型值:

            duration  属性为动画持续时间

            说明:   时间以毫秒为单位



        布尔型值:

            fillAfter 属性 当设置为true ,该动画转化在动画结束后被应用

-->
复制代码

<translate>

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">

<translate

android:fromXDelta="30"

android:toXDelta="-80"

android:fromYDelta="30"

android:toYDelta="300"

android:duration="2000"

/>

<!-- translate 位置转移动画效果

        整型值:

            fromXDelta 属性为动画起始时 X坐标上的位置   

            toXDelta   属性为动画结束时 X坐标上的位置

            fromYDelta 属性为动画起始时 Y坐标上的位置

            toYDelta   属性为动画结束时 Y坐标上的位置

            注意:

                     没有指定fromXType toXType fromYType toYType 时候,

                     默认是以自己为相对参照物            

        长整型值:

            duration  属性为动画持续时间

            说明:   时间以毫秒为单位

-->

</set>
复制代码

<rotate>

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">

<rotate

        android:interpolator="@android:anim/accelerate_decelerate_interpolator"

        android:fromDegrees="0"

        android:toDegrees="+350"        

        android:pivotX="50%"

        android:pivotY="50%"    

        android:duration="3000" /> 

<!-- rotate 旋转动画效果

       属性:interpolator 指定一个动画的插入器

             在我试验过程中,使用android.res.anim中的资源时候发现

             有三种动画插入器:

                accelerate_decelerate_interpolator   加速-减速 动画插入器

                accelerate_interpolator               加速-动画插入器

                decelerate_interpolator               减速- 动画插入器

             其他的属于特定的动画效果



       浮点数型值:

            fromDegrees 属性为动画起始时物件的角度   

            toDegrees   属性为动画结束时物件旋转的角度 可以大于360度  





            说明:

                     当角度为负数——表示逆时针旋转

                     当角度为正数——表示顺时针旋转             

                     (负数from——to正数:顺时针旋转)  

                     (负数from——to负数:逆时针旋转)

                     (正数from——to正数:顺时针旋转)

                     (正数from——to负数:逆时针旋转)      



            pivotX     属性为动画相对于物件的X坐标的开始位置

            pivotY     属性为动画相对于物件的Y坐标的开始位置



            说明:        以上两个属性值 从0%-100%中取值

                         50%为物件的X或Y方向坐标上的中点位置



        长整型值:

            duration  属性为动画持续时间

            说明:       时间以毫秒为单位

-->

</set>
复制代码


如何使用XML中的动画效果

public static Animation loadAnimation (Context context, int id)

//第一个参数Context为程序的上下文   

//第二个参数id为动画XML文件的引用

//例子:

myAnimation= AnimationUtils.loadAnimation(this,R.anim.my_action);

//使用AnimationUtils类的静态方法loadAnimation()来加载XML中的动画XML文件
复制代码

如何在Java代码中定义动画
//在代码中定义 动画实例对象

private Animation myAnimation_Alpha;

private Animation myAnimation_Scale;

private Animation myAnimation_Translate;

private Animation myAnimation_Rotate;



    //根据各自的构造方法来初始化一个实例对象

myAnimation_Alpha=new AlphaAnimation(0.1f, 1.0f);



myAnimation_Scale =new ScaleAnimation(0.0f, 1.4f, 0.0f, 1.4f,

             Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);



myAnimation_Translate=new TranslateAnimation(30.0f, -80.0f, 30.0f, 300.0f);



myAnimation_Rotate=new RotateAnimation(0.0f, +350.0f,

               Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF, 0.5f);
复制代码


Android动画解析--JavaCode

AlphaAnimation
① AlphaAnimation类对象定义

   1. private AlphaAnimation myAnimation_Alpha;
复制代码

② AlphaAnimation类对象构造
AlphaAnimation(float fromAlpha, float toAlpha)

//第一个参数fromAlpha为 动画开始时候透明度

//第二个参数toAlpha为 动画结束时候透明度

myAnimation_Alpha=new AlphaAnimation(0.1f, 1.0f);

//说明:

//                0.0表示完全透明

//                1.0表示完全不透明
复制代码

③ 设置动画持续时间
myAnimation_Alpha.setDuration(5000);

//设置时间持续时间为 5000毫秒
复制代码

ScaleAnimation

① ScaleAnimation类对象定义
private AlphaAnimation myAnimation_Alpha;
复制代码

② ScaleAnimation类对象构造
ScaleAnimation(float fromX, float toX, float fromY, float toY,

           int pivotXType, float pivotXValue, int pivotYType, float pivotYValue)

//第一个参数fromX为动画起始时 X坐标上的伸缩尺寸   

//第二个参数toX为动画结束时 X坐标上的伸缩尺寸    

//第三个参数fromY为动画起始时Y坐标上的伸缩尺寸   

//第四个参数toY为动画结束时Y坐标上的伸缩尺寸 

/*说明:

                    以上四种属性值   

                    0.0表示收缩到没有

                    1.0表示正常无伸缩    

                    值小于1.0表示收缩 

                    值大于1.0表示放大

*/

//第五个参数pivotXType为动画在X轴相对于物件位置类型 

//第六个参数pivotXValue为动画相对于物件的X坐标的开始位置

//第七个参数pivotXType为动画在Y轴相对于物件位置类型  

//第八个参数pivotYValue为动画相对于物件的Y坐标的开始位置

myAnimation_Scale =new ScaleAnimation(0.0f, 1.4f, 0.0f, 1.4f,

             Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
复制代码

③ 设置动画持续时间
myAnimation_Scale.setDuration(700);

//设置时间持续时间为 700毫秒
复制代码

TranslateAnimation


① TranslateAnimation类对象定义
private AlphaAnimation myAnimation_Alpha;
复制代码

② TranslateAnimation类对象构造
TranslateAnimation(float fromXDelta, float toXDelta,

                       float fromYDelta, float toYDelta)

//第一个参数fromXDelta为动画起始时 X坐标上的移动位置   

//第二个参数toXDelta为动画结束时 X坐标上的移动位置     

//第三个参数fromYDelta为动画起始时Y坐标上的移动位置    

//第四个参数toYDelta为动画结束时Y坐标上的移动位置
复制代码

③ 设置动画持续时间
myAnimation_Translate.setDuration(2000);

//设置时间持续时间为 2000毫秒
复制代码

RotateAnimation
① RotateAnimation类对象定义
private AlphaAnimation myAnimation_Alpha;
复制代码

② RotateAnimation类对象构造
RotateAnimation(float fromDegrees, float toDegrees,

            int pivotXType, float pivotXValue, int pivotYType, float pivotYValue)

//第一个参数fromDegrees为动画起始时的旋转角度   

//第二个参数toDegrees为动画旋转到的角度  

//第三个参数pivotXType为动画在X轴相对于物件位置类型 

//第四个参数pivotXValue为动画相对于物件的X坐标的开始位置

//第五个参数pivotXType为动画在Y轴相对于物件位置类型  

//第六个参数pivotYValue为动画相对于物件的Y坐标的开始位置

myAnimation_Rotate=new RotateAnimation(0.0f, +350.0f,

               Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF, 0.5f);
复制代码

③ 设置动画持续时间
myAnimation_Rotate.setDuration(3000);

//设置时间持续时间为 3000毫秒
复制代码

如何使用Java代码中的动画效果
使用从View父类继承过来的方法startAnimation()来为View或是子类View等等添加一个动画效果
public void startAnimation (Animation animation)
复制代码
分享到:
评论

相关推荐

    安卓Android源码——animation图片移动效果.zip

    本资源"安卓Android源码——animation图片移动效果.zip"提供了一个关于如何在Android应用中实现图片移动的动画效果的实例。以下是对这个主题的详细解释: 一、Android Animation概述 Android中的动画主要分为两种...

    安卓Android源码——(Animation动画).zip

    这份"安卓Android源码——(Animation动画).zip"文件很可能包含了关于这三种动画类型的详细实现和解析。 1. **视图动画(View Animation)**: 视图动画是Android早期版本中提供的动画机制,主要通过`Animation`类...

    Android源码——animation图片移动效果.zip

    "Android源码——animation图片移动效果.zip"这个资源包显然包含了关于如何在Android应用中实现图片移动动画的示例代码和图片素材。这里我们将深入探讨Android中图片移动动画的实现方式及其关键知识点。 1. **...

    安卓Android源码——animation.rar

    在“安卓Android源码——animation.rar”这个压缩包中,我们很可能是得到了与Android系统动画相关的源代码。为了深入理解Android动画的工作原理,我们可以探讨以下几个关键知识点: 1. **动画类型**: - **属性...

    安卓Android源码——animation的结合蝴蝶飞的动画,使用动画里面的几种类型.zip

    这个“安卓Android源码——animation的结合蝴蝶飞的动画,使用动画里面的几种类型.zip”文件就是一个很好的例子,展示了如何在Android应用中实现蝴蝶飞舞的动画效果,利用了Android内置的不同动画类型。 首先,...

    安卓Android源码——(Animation动画).rar

    本资源"安卓Android源码——(Animation动画).rar"很可能是针对Android平台动画实现的一份详细教程或示例代码集。 Android中的动画主要分为两大类:属性动画(Property Animation)和视图动画(View Animation)。...

    安卓Android源码——animation1.rar

    综上所述,`animation1.rar`中的源码可能涵盖了Android动画系统的各个方面,包括但不限于上述知识点。通过深入研究这些代码,开发者可以学习到如何在Android应用中创建出各种动态效果,从而提升应用的吸引力和用户...

    Android属性动画——实现灵动菜单效果

    在Android开发中,属性动画(Property Animation)是一个强大的工具,它可以为用户界面带来生动而丰富的动态效果。在本文中,我们将深入探讨如何使用属性动画来实现一个灵动菜单的效果。灵动菜单通常指的是那些在...

    android自定义效果——随机抽奖

    总的来说,实现"android自定义效果——随机抽奖"涉及的知识点包括:自定义视图的创建与绘制、Android动画机制(特别是`ObjectAnimator`)、随机数生成、触摸事件处理以及视图的优化。掌握这些技能,开发者可以创建出...

    android 动画实现——ViewFilpper

    在Android开发中,动画是提升用户体验的关键因素之一。`ViewFlipper`是Android SDK提供的一种方便的布局组件,专门用于实现视图之间的切换效果,比如翻页、滑动等。相较于传统的`Animation`类,`ViewFlipper`具有更...

    Android属性动画——自定义Drawable(Robots)

    在Android开发中,属性动画(Property Animation)是一个强大的工具,它可以改变View对象的视觉状态,创造出丰富的动态效果。本文将深入探讨如何通过自定义Drawable来实现Android属性动画,特别是使用"Robots"这个...

    安卓Andriod源码——animation的结合蝴蝶飞的动画,使用动画里面的几种类型.zip

    让我们深入探讨这个"安卓Andriod源码——animation的结合蝴蝶飞的动画,使用动画里面的几种类型.zip"的实现原理和相关知识点。 首先,Android中的动画可以分为两大类:属性动画(Property Animation)和视图动画...

    安卓Android源码——View中添加Animation.zip

    本资源包"安卓Android源码——View中添加Animation.zip"主要关注如何在Android的View组件中应用动画效果。接下来,我们将深入探讨Android视图动画的实现原理及其在实际开发中的应用。 一、Android动画类型 1. **帧...

    安卓Android源码——高仿墨迹天气背景动画效果-云,风,雪等.zip

    总的来说,这个源码项目涵盖了Android动画系统、粒子效果、自定义视图以及可能的图形优化等多个知识点,对于想要提升Android应用视觉体验的开发者来说,是一份非常有价值的参考资料。通过学习和分析这个项目,开发者...

    Android开发笔记——UI基础编程

    这份"Android开发笔记——UI基础编程"的资料集包含了两部分:新版Android开发教程+笔记七--基础UI编程1.pdf和新版Android开发教程+笔记七--基础UI编程2.pdf,将深入讲解Android应用程序中用户界面的设计与实现。...

    Android——给控件添加动画

    在Android开发中,给控件添加动画是一种提升用户体验的有效手段,可以使用户界面更加生动和吸引人。本篇文章将深入探讨如何在Android应用中为控件添加动画,包括基本的动画类型、实现方式以及最佳实践。 一、动画...

    基于Android的Android项目之——页面特效集合(附源码).zip

    "基于Android的Android项目之——页面特效集合(附源码)"提供了一系列的示例代码,旨在帮助开发者,尤其是毕业生,掌握和应用各种动画效果。这个项目不仅包含源码,还兼容了多种开发环境,如Android Studio、...

    安卓Android源码——动画效果切换Activity动画 控件位置调整.zip

    本资源"安卓Android源码——动画效果切换Activity动画 控件位置调整.zip"正是针对这一主题,包含了使用translate、scale、alpha和rotate四种基本动画类型实现Activity切换的源代码示例。 1. **translate动画**:...

    Android基础——Tween动画、Drawable动画、Property动画、MaterialDesign动画、Trasition动画

    综上所述,Android动画系统为开发者提供了多种方式来增强应用的视觉表现力。Tween动画适合简单的动画需求,Drawable动画适合创建帧动画,Property动画则提供了强大的属性动画功能,Material Design动画则为应用带来...

Global site tag (gtag.js) - Google Analytics