android简单动画

Android 平台提供了两类动画。 

一类是Tween动画,就是对场景里的对象不断的进行图像变化来产生动画效果 (旋转、平移、放缩和渐变)。

二类就是 Frame动画,即顺序的播放事先做好的图像,与gif图片原理类似。


1:AnimationDrawable(background中设置背景)

Frame动画通过一系列Drawable依次显示来模拟动画的效果

在布局中放一个ImageView控件,

里面的android:background="@drawable/wifi"中的wifi是写在drawable文件夹下面的wifi.xml,内容如下:

android:onshot如果定义为true的话,此动画只会执行一次,如果为false则一直循环。

<item>元素代表一帧动画,android:drawable指定此帧动画所对应的图片资源,android:druation代表此帧持续的时间,整数,单位为毫秒

里面的drawable图片:


在代码中给该ImageView的控件设置监听,然后:


做出来的动画就是wifi信号一点一点增强的动画



2:Tween动画

2.1  AnimationSet

在布局中的动画(通过anim文件设置多重动画)

在res/anim文件夹里面的anim.xml文件,内容:(可以是多重动画)
android简单动画_第1张图片


在布局文件中定义的ImageView:


在代码中加载动画文件:

android简单动画_第2张图片

也可以在代码中实现多重动画:

AnimationSet set = new AnimationSet(true);
set.addAnimation(alpha);
set.addAnimation(rotate);
set.setDuration(3000);
image_scale.setAnimation(set);

//alpha是透明度动画,这些都是在之前取设置,这里只是记下调用,详见下面的动画代码


2.2:动画(旋转、平移、放缩和渐变)

AlphaAnimation(透明度),RotateAnimation(旋转),

ScaleAnimation(缩放),TranslateAnimation(位置移动)



以自定义View为例,该View很简单,画面上只有一个图片。 现在我们要对整个View分别实现各种Tween动画效果。

 AlphaAnimation(透明度)

 通过代码实现 AlphaAnimation,如下:

AlphaAnimation alpha = new AlphaAnimation(0, 1);
alpha.setDuration(3000);
alpha.setRepeatMode(Animation.RESTART);
alpha.setRepeatCount(3);
image_alpha.startAnimation(alpha);

其中AlphaAnimation类第一个参数fromAlpha表示动画起始时的透明度, 第二个参数toAlpha表示动画结束时的透明度。 

setDuration用来设置动画持续时间。


RotateAnimation(旋转)

通过代码实现 AlphaAnimation,如下:

// RotateAnimation rotate=new RotateAnimation(0, 360);//左上角转
// 右上角转
RotateAnimation rotate = new RotateAnimation(0, 360,Animation.RELATIVE_TO_SELF, 1, Animation.RELATIVE_TO_SELF, 0);
// 自己的中心
//rotate = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f,Animation.RELATIVE_TO_SELF, 0.5//f);
// 父的中心
//rotate = new RotateAnimation(0, 360, Animation.RELATIVE_TO_PARENT,0.5f, Animation.RELATIVE_TO_PARENT,// 0.5f);
rotate.setDuration(3000);
image_rotate.setAnimation(rotate);

其中RotateAnimation类第一个参数fromDegrees表示动画起始时的角度, 第二个参数toDegrees表示动画结束时的角度。 

另外还可以设置伸缩模式pivotXType、pivotYType, 伸缩动画相对于x,y 坐标的开始位置pivotXValue、pivotYValue等。



ScaleAnimation(缩放)

ScaleAnimation scale = new ScaleAnimation(0, 1, 0, 1);
scale = new ScaleAnimation(1, 0, 1, 1, Animation.RELATIVE_TO_SELF,
0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
scale.setDuration(3000);
image_scale.setAnimation(scale);

ScaleAnimation类中

第一个参数fromX ,第二个参数toX:分别是动画起始、结束时X坐标上的伸缩尺寸。

第三个参数fromY ,第四个参数toY:分别是动画起始、结束时Y坐标上的伸缩尺寸。

另外还可以设置伸缩模式pivotXType、pivotYType, 伸缩动画相对于x,y 坐标的开始位置pivotXValue、pivotYValue等。


TranslateAnimation(位置移动)

代码:

[java]  view plain copy print ?
  1. //初始化  
  2. Animation translateAnimation = new TranslateAnimation(0.1f, 100.0f,0.1f,100.0f);  
  3. //设置动画时间                translateAnimation.setDuration(1000);  
  4.                             this.startAnimation(translateAnimation);  
  TranslateAnimation类

 第一个参数fromXDelta ,第二个参数toXDelta:分别是动画起始、结束时X坐标。

第三个参数fromYDelta ,第四个参数toYDelta:分别是动画起始、结束时Y坐标。





你可能感兴趣的:(动画,android,imageview,android应用)