切换方式一:java代码切换。

只是很简单的调用一个api函数:overridePendingTransition(int enterAnim, int outAnim)

eg:

假设有两个Activity,分别为A和B。

当在A中启动B时,可以使用如下方式添加动画:

首先在xml中定义两个动画,放在R.anim文件夹目录下:

right_left_out.xml:


<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
    <translate  
        android:duration="400"  
        android:fromXDelta="0"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="-100%p"  
        android:toYDelta="0" />  
</set>


right_left_in.xml:


<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
    <translate  
        android:duration="400"  
        android:fromXDelta="100%p"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="0"  
        android:toYDelta="0" />  
</set>


然后在A中启动B时,就可以利用这两个动画定义文件让A和B的切换过程产生动画下过,如下代码片段演示:


Intent intent = new Intent(A.this, B.class);  
A.this.startActivity(intent);  
  
//参数一是下一个Activity的进入动画,参数二是当前Activity的退出动画  
overridePendingTransition(R.anim.right_left_in, R.anim.right_left_out);



在B中返回A时

,可以使用如下动画:

left_right_out.xml:


<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
    <translate  
        android:duration="400"  
        android:fromXDelta="0"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="100%p"  
        android:toYDelta="0" />  
</set>


left_right_in.xml:


<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
    <translate  
        android:duration="400"  
        android:fromXDelta="-100%p"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="0"  
        android:toYDelta="0" />  
</set>

java代码:


B.this.finish();  
overridePendingTransition(R.anim.left_right_in, R.anim.left_right.out);


 如果希望在用户按返回键是从B退回到A时也能够有动画效果,则需要在B中截取按钮事件,并手动结束当前Activity。代码片段如下:

@Override  
public boolean onKeyUp(int keyCode, KeyEvent event)  
{  
    if (keyCode == KeyEvent.KEYCODE_BACK)  
    {  
        B.this.finish();  
                overridePendingTransition(R.anim.left_right_in, R.anim.left_right_out);  
            return true;  
    }  
    return super.onKeyUp(keyCode, event);  
}




切换方式二:通过修改主题样式修改。

在Manifest文件中声明Activity时,可以通过android:theme属性设置Activity的主题。主题中定义了关于Activity外观的很多特性。同时,主题中还可以定义Activity的切换动画。通过主题的形式定义的Activity切换动画,甚至可以超越API的限制,在2.0以下的系统版本中依然能够设置Activity切换动画。

下面就一个简单的例子说明怎么定义包含Activity切换动画的主题。

         首先,我们先看一下包含动画的主题是怎么定义的。在R.values文件夹中新建一个style.xml的文件,在其中插入一个<style />节点,声明一个主题,代码如下:

R.values.style:

<style name="Activity.Theme" mce_bogus="1" parent="@android:style/Theme.NoTitleBar">  
    <item name="android:windowAnimationStyle">@style/anim_activity</item>  
</style>

可以看到,以上主题的父主题是@android:style/Theme.NoTitleBar, 就是继承自系统主题的大部分属性。

其中有一个"android:windowAnimationStyle"属性是由我们自定义的,定位的位置同样在R.values.style文件中。代码如下:

<style name="anim_activity" mce_bogus="1" parent="@android:style/Animation.Activity">  
    <item name="android:activityOpenEnterAnimation">@anim/activity_open_in_anim</item>  
    <item name="android:activityOpenExitAnimation">@anim/activity_open_out_anim</item>  
    <item name="android:activityCloseEnterAnimation">@anim/activity_close_in_anim</item>  
    <item name="android:activityCloseExitAnimation">@anim/activity_close_out_anim</item>  
</style>



现在假设有两个Activity, A 和 B。 在A中可以启动B. 同时,A,B的theme属性均设置为上面定义的属性。那么,以上动画的发生时机如下:

(1)当A启动B时,A退出,B进入,A退出时的动画名称为android:activityOpenExitAnimation,动画文件为

R.anim.activity_open_out_anim. B进入时的动画名称为android:activityOpenEnterAnimation, 动画文件为R.anim.activity_open_in_anim.

(2)当B结束时,B退出,A进入。B退出的动画名称为android:activityCloseExitAnimation, 动画文件为R.anim.activity_close_out_anim. A进入时的动画名称为android:activityCloseEnterAnimation, 动画文件为R.anim.activity_close_in_anim. 

 

通过以上设置,Activity切换时便可以显示切换动画效果。

下面四个文件定位的是上面用到的四个动画。

R.anim.activity_close_in_anim.xml



<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
  
    <translate  
        android:duration="400"  
        android:fromXDelta="-100%p"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="0"  
        android:toYDelta="0" />  
  
</set>




R.anim.activity_close_out_anim.xml


<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
    <translate  
        android:duration="400"  
        android:fromXDelta="0"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="100%p"  
        android:toYDelta="0" />  
</set>




R.anim.activity_open_in_anim.xml

<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
  
    <translate  
        android:duration="400"  
        android:fromXDelta="100%p"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="0"  
        android:toYDelta="0" />  
  
</set>


R.anim.activity_open_out_anim.xml


<?xml version="1.0" encoding="utf-8"?>  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  
  
    <translate  
        android:duration="400"  
        android:fromXDelta="0"  
        android:fromYDelta="0"  
        android:interpolator="@android:anim/decelerate_interpolator"  
        android:toXDelta="-100%p"  
        android:toYDelta="0" />  
  
</set>