Activity打开退出动画:从底部向上打开,退出时从上至下退出,避免Activity退出时屏幕短暂黑屏

第一步:创建进入动画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就是上文所述的前者)
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值