现在的位置: 首页 > 综合 > 正文

Android动画(二)

2018年04月19日 ⁄ 综合 ⁄ 共 2366字 ⁄ 字号 评论关闭

转自:http://blog.csdn.net/zhy_cheng/article/details/7951092

Animation也可以放在XML文件中,这样程序的可维护性提高了。在XML中写动画的步骤如下

1.在res文件夹下面新建一个名为anim的文件夹

2.创建xml文件,并首先加入set标签,改标签如下

<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator">
  
</set>

3.在该标签当中加入rotate,alpha,scale或者translate标签

4.在代码当中使用AnimationUtils加载xml文件,并生成Animation对象

Alpha动画

[java] view
plain
copy

  1. <span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:interpolator="@android:anim/accelerate_interpolator">  
  4.     <alpha  
  5.         android:fromAlpha="1.0"  
  6.         android:toAlpha="0.0"  
  7.         android:startOffset="500"  
  8.         android:duration="2000"  
  9.             />  
  10.   
  11. </set></span>  

Animation a=AnimationUtils.loadAnimation(this, R.anim.alpha);
iv.startAnimation(a);

Scale动画

[html] view
plain
copy

  1. <span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:interpolator="@android:anim/accelerate_interpolator">  
  4.     <scale  
  5.         android:fromXScale="1.0"  
  6.         android:toXScale="0.0"  
  7.         android:fromYScale="1.0"  
  8.         android:toYScale="0.0"  
  9.         android:pivotX="50%"  
  10.         android:pivotY="50%"  
  11.         android:duration="2000"  
  12.     />  
  13.   
  14. </set></span>  


Rotate动画

[html] view
plain
copy

  1. <span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:interpolator="@android:anim/accelerate_interpolator">  
  4.     <rotate  
  5.         android:fromDegrees="0"  
  6.         android:toDegrees="400"  
  7.         android:pivotX="50%"  
  8.         android:pivotY="50%"  
  9.         android:duration="3000"  
  10.     />  
  11.   
  12. </set></span>  


Translate动画

[html] view
plain
copy

  1. <span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:interpolator="@android:anim/accelerate_interpolator">  
  4.     <translate  
  5.         android:fromXDelta="50%"  
  6.         android:toXDelta="100%"  
  7.         android:fromYDelta="50%"  
  8.         android:toYDelta="100%"  
  9.         android:duration="3000"  
  10.     />  
  11.   
  12. </set></span>  


这里重点提一下android:pivotX和android:pivotY和android:fromXDelta,android:toXDelta

android:pivotX="50"使用绝对坐标

android:pivotX="50%"相对自己

android:pivotX="50%p"相对父控件

抱歉!评论已关闭.