第一步:创建进入动画xml文件:activity_tab_pay_open
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- 窗口进入动画 -->
<translate
android:duration="300"
android:fromYDelta="100%p"
android:toYDelta="0" />
</set>
第二步:创建退出动画xml文件:activity_tab_pay_close
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- tab页付款页窗口退出动画 -->
<translate
android:duration="300"
android:fromYDelta="25"
android:toYDelta="100%p" />
</set>
第三步:在style.xml文件中,添加如下style代码:
<style name="NarbarTransparent" parent="android:Theme.NoTitleBar">
<!-- 将Activity的Theme设置成透明 -->
<item name="android:windowIsTranslucent">true</item>
<item name="android:activityOpenEnterAnimation">@anim/activity_tab_pay_open</item>
<item name="android:activityOpenExitAnimation">@anim/activity_tab_pay_open</item>
<item name="android:activityCloseEnterAnimation">@anim/activity_tab_pay_close</item>
<item name="android:activityCloseExitAnimation">@anim/activity_tab_pay_close</item>
</style>
第四步:引用此style,在清单文件中对应的activity添加:android:theme="@style/NarbarTransparent"
第五步:通过Intent跳转到目标页面的代码之后(就是在“context.startActivity(intent);”之后)添加:
context.overridePendingTransition(R.anim.activity_tab_pay_open, android.R.anim.fade_out);
第六步:重写目标界面activity的finish方法:
@Override
public void finish() {
super.finish();
// 设置activity退出动画
TabPayActivity.this.overridePendingTransition(R.anim.activity_tab_pay_close, R.anim.activity_tab_pay_close);
}
说明:
@android:activityOpenEnterAnimation,// 表示新的activity创建进入效果
@android:activityOpenExitAnimation,// 表示activity还没有finish()下退出效果
@android:activityCloseEnterAnimation,// 表示上一个 activity返回进入效果
@android:activityCloseExitAnimation ,// 表示的是activity finish()之后退出效果...
android.R.anim.fade_out是android系统的动画,作用是前者activity退出动画(前者是指:比如:A跳转到B,A、B都是activity,A就是上文所述的前者)
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- 窗口进入动画 -->
<translate
android:duration="300"
android:fromYDelta="100%p"
android:toYDelta="0" />
</set>
第二步:创建退出动画xml文件:activity_tab_pay_close
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- tab页付款页窗口退出动画 -->
<translate
android:duration="300"
android:fromYDelta="25"
android:toYDelta="100%p" />
</set>
第三步:在style.xml文件中,添加如下style代码:
<style name="NarbarTransparent" parent="android:Theme.NoTitleBar">
<!-- 将Activity的Theme设置成透明 -->
<item name="android:windowIsTranslucent">true</item>
<item name="android:activityOpenEnterAnimation">@anim/activity_tab_pay_open</item>
<item name="android:activityOpenExitAnimation">@anim/activity_tab_pay_open</item>
<item name="android:activityCloseEnterAnimation">@anim/activity_tab_pay_close</item>
<item name="android:activityCloseExitAnimation">@anim/activity_tab_pay_close</item>
</style>
第四步:引用此style,在清单文件中对应的activity添加:android:theme="@style/NarbarTransparent"
第五步:通过Intent跳转到目标页面的代码之后(就是在“context.startActivity(intent);”之后)添加:
context.overridePendingTransition(R.anim.activity_tab_pay_open, android.R.anim.fade_out);
第六步:重写目标界面activity的finish方法:
@Override
public void finish() {
super.finish();
// 设置activity退出动画
TabPayActivity.this.overridePendingTransition(R.anim.activity_tab_pay_close, R.anim.activity_tab_pay_close);
}
说明:
@android:activityOpenEnterAnimation,// 表示新的activity创建进入效果
@android:activityOpenExitAnimation,// 表示activity还没有finish()下退出效果
@android:activityCloseEnterAnimation,// 表示上一个 activity返回进入效果
@android:activityCloseExitAnimation ,// 表示的是activity finish()之后退出效果...
android.R.anim.fade_out是android系统的动画,作用是前者activity退出动画(前者是指:比如:A跳转到B,A、B都是activity,A就是上文所述的前者)