Android中的动画研究
本文主要研究Android中的三种动画,第一种是单个View的各种动画效果,第二种是两个Active切换时的动画效果,第三种是类似于Gif的Frame By Frame动画效果,其中View的各种动画包括在xml文件中定义和代码中定义两种方式。
一、??????? 动画基本类型:
如下表所示,Android的动画由四种类型组成,即可在xml中定义,也可在代码中定义,如下所示:
? | XML | CODE |
渐变透明度动画效果 | alpha | AlphaAnimation |
渐变尺寸伸缩动画效果 | scale | ScaleAnimation |
画面转换位置移动动画效果 | translate | TranslateAnimation |
画面转移旋转动画效果 | rotate | RotateAnimation |
二、??????? 如何在XML文件中定义动画
1.????????? alpha
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<!--? 表示透明度从0.1到1.0,时长为3000ms。-->
<alpha
android:fromAlpha="0.1"
android:toAlpha="1.0"
android:duration="3000"
/>
</set>
2.????????? 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 指定一个动画的插入器,共三种:
??????????? 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 ,该动画转化在动画结束后被应用
-->
3.????????? 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>
4.????????? 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 指定一个动画的插入器,共三种:
??????????????? 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文件
findViewById(R.id.pw).startAnimation(myAnimation);//用此方法来启动动画
四、??????? 如何在Java代码中定义动画
1.????????? 代码:
//在代码中定义 动画实例对象
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);
2.????????? 分析
1.1 AlphaAnimation
第一步:AlphaAnimation类对象定义
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毫秒
?
1.2 ScaleAnimation
第一步:ScaleAnimation类对象定义
private AlphaAnimation myAnimation_Scale;
第二步: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毫秒
1.3 TranslateAnimation
第一步:TranslateAnimation类对象定义
private AlphaAnimation myAnimation_Translate;
第二步:TranslateAnimation类对象构造
TranslateAnimation(float fromXDelta, float toXDelta,
?????????????????????? float fromYDelta, float toYDelta)
?
//第一个参数fromXDelta为动画起始时 X坐标上的移动位置
//第二个参数toXDelta为动画结束时 X坐标上的移动位置
//第三个参数fromYDelta为动画起始时Y坐标上的移动位置
//第四个参数toYDelta为动画结束时Y坐标上的移动位置
?
第三步:设置动画持续时间 m
myAnimation_Translate.setDuration(2000);
?
1.4 RotateAnimation
第一步:RotateAnimation类对象定义
private AlphaAnimation myAnimation_Rotate;
?
第二步: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);
五、??????? 如何使用Java代码中的动画效果
使用从View父类继承过来的方法startAnimation()来为View或是子类View等等添加一个动画效果
public void startAnimation (Animation animation)
六、??????? 转场动画
在StartActivity后即调用overridePendingTransition(int enterAnim, int exitAnim)
//in
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">??
??? <translate??
??? android:fromXDelta="100%p"???
??? android:toXDelta="0"???
??? android:duration="500"/>??
</set>
//out
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">??
??? <translate??
??? android:fromXDelta="0"???
??? android:toXDelta="-100%p"???
??? android:duration="500"/>??
</set>
?
七、??????? Frame By Frame
Frame by frame 指将一幅幅图片按序播放,效果像gif动画:
第一步:将用到的图片资源加到工程。
第二步:在xml里定义动画。
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
??? android:oneshot="false">
??? <item android:drawable="@drawable/rkof" android:duration="200" />
??? <item android:drawable="@drawable/hkof" android:duration="200" />
??? <item android:drawable="@drawable/gkof" android:duration="200" />
??? <item android:drawable="@drawable/fkof" android:duration="200" />
??? <item android:drawable="@drawable/ekof" android:duration="200" />
??? <item android:drawable="@drawable/dkof" android:duration="200" />
??? <item android:drawable="@drawable/ckof" android:duration="200" />
??? <item android:drawable="@drawable/bkof" android:duration="200" />
??? <item android:drawable="@drawable/akof" android:duration="200" />
</animation-list>
<!-- android:oneshot属性为true,它将会在最后一帧停下来,如果设置
为false这个动画将循环播放 -->
第三步:定义AnimationDrawable对像
?????? ImageView myImage = (ImageView) findViewById(R.id.rocket_image);
?????? myImage.setBackgroundResource(R.anim.myframeanimation);
?????? AnimationDrawable frameAnimation=(AnimationDrawable) myImage.getBackground();
第四步:播放
?????? frameAnimation.start()
ApiDemo中的动画研究:
?
Android 系统所支持的动画特效
1.?????? 平滑:???????????????????? Graphics/AnimateDrawables
2.?????? 淡入淡出??????? App/Activity/Animation
3.?????? 放大缩小??????? App/Activity/Animation && Graphics/ScaleToFit
4.?????? 翻转?????????????? Views/Animation/3D Transition && Graphics/PolyToPoly
5.?????? 透明?????????????? App/Activity/Translucent
6.?????? 模糊?????????????? App/Activity/Translucent Blur
7.?????? Overlay?????????? Graphics/SurfaceView OverLay
8.?????? 反弹效果??????? Views/Animation/Shake
9.?????? 文字效果 ????? Views/Animation/Push && Views/Animation/Interpolators
?
?
ReadCode
1.?????? FingerPaint
1.1.? path用于存储一次绘画,mouse down to mouse up
1.2.? Bitmap用于存储所有绘画,activity onCreate to OnDestory.
2.?????? AnimateDrawables
1.1.? 在View中创建变量AnimateDrawable
1.2.? Drawable 从资源中获取图片。
1.3.? Animation 定义动画
1.4.? 开始动画
3.?????? Animation
1.1.??? overridePendingTransition(R.anim.fade, R.anim.hold);
1.2.??? overridePendingTransition(R.anim.zoom_enter, R.anim.zoom_exit);
4.?????? ScaleToFit
5.?????? PolyToPoly
1.1. 画线 drawLine
1.2. 画矩形 drawRect
1.3. 设置矩阵 关键,具体算法不知。
6.?????? Translucent
1.1. setContentView(R.layout.translucent_background);
7.?????? Translucent Blur
1.1. getWindow().setFlags
1.2. WindowManager.LayoutParams.FLAG_BLUR_BEHIND,
1.3. WindowManager.LayoutParams.FLAG_BLUR_BEHIND);
8.?????? SufaceView Overlay
1.1??? CubeRenderer
1.2??? GLSurfaceView
9.?????? Shake
10.?? Interpolators
?
?
一、2D
1.?????? Bitmap with alpha ort Alpha bitblt。
2.?????? 平滑移动效果。
3.?????? Arc Fills
4.?????? BitmapDecode 旗帜飘动特效。
5.?????? Mesh 网格特效。
6.?????? Bitmap Pixels 渐变填充。
7.?????? Camera Preview
8.?????? Clipping
9.?????? Color Filters
10.?? Color Matrix
11.?? Compass
12.?? Create Bitmap
13.?? Layers
14.?? Measure Text
15.?? Path Effect
16.?? Pattern
17.?? Poly to Poly
18.?? Regions
19.?? RoundRects
20.?? ScaleToFit
21.?? SurfaceView Overlay
22.?? Sweeps
23.?? Vertices
?
二、3D
1.?????? Compressed Texture
2.?????? Cube Map
3.?????? GlSurfaceView
4.?????? Kube
5.?????? Matrix Palette Skinning
6.?????? Sprite Text
7.?????? Textured Triangle
8.?????? Touch Rotate
9.?????? Translucent GLSurfaceView
?