Android的activity跳转动画实现

  Android 在进行activity跳转时原生动画比较突兀,虽然google官方出了一个方法 overridePendingTransition(int enterAnim, intexitAnim),但经过实际的测试发现效果并不如人意,在跳转时前一个界面会出现运动到一半就变黑消失的情况,继而在寻找之后终于发现了一个比较有效的方法,就是自己写一个theme主题,将其中的动画的style继承自@android:style/Animation.Activity,实现具体方法如下

     首先在res/anim下面新建4个xml文件,分别是

 1.anim_enter.xml

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:interpolator="@android:anim/decelerate_interpolator" >  
  4.   
  5.     <scale  
  6.         android:duration="@android:integer/config_mediumAnimTime"  
  7.         android:fromXScale="0.0"  
  8.         android:fromYScale="0.0"  
  9.         android:pivotX="69.99999%"  
  10.         android:pivotY="100.0%"  
  11.         android:toXScale="1.0"  
  12.         android:toYScale="1.0" />  
  13.   
  14.     <alpha  
  15.         android:duration="@android:integer/config_mediumAnimTime"  
  16.         android:fromAlpha="0.0"  
  17.         android:toAlpha="1.0" />  
  18.   
  19. </set>  
<?xml version="1.0" encoding="UTF-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator" >

    <scale
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromXScale="0.0"
        android:fromYScale="0.0"
        android:pivotX="69.99999%"
        android:pivotY="100.0%"
        android:toXScale="1.0"
        android:toYScale="1.0" />

    <alpha
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromAlpha="0.0"
        android:toAlpha="1.0" />

</set>
2.anim_exit.xml

  1. <?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.   
  5.     <scale  
  6.         android:duration="@android:integer/config_mediumAnimTime"  
  7.         android:fromXScale="1.0"  
  8.         android:fromYScale="1.0"  
  9.         android:pivotX="69.99999%"  
  10.         android:pivotY="100.0%"  
  11.         android:toXScale="0.0"  
  12.         android:toYScale="0.0" />  
  13.   
  14.     <alpha  
  15.         android:duration="@android:integer/config_mediumAnimTime"  
  16.         android:fromAlpha="1.0"  
  17.         android:toAlpha="0.0" />  
  18.   
  19. </set>  
<?xml version="1.0" encoding="UTF-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator" >

    <scale
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromXScale="1.0"
        android:fromYScale="1.0"
        android:pivotX="69.99999%"
        android:pivotY="100.0%"
        android:toXScale="0.0"
        android:toYScale="0.0" />

    <alpha
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromAlpha="1.0"
        android:toAlpha="0.0" />

</set>
3.back_enter.xml

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:interpolator="@android:anim/decelerate_interpolator" >  
  4.   
  5.     <scale  
  6.         android:duration="@android:integer/config_mediumAnimTime"  
  7.         android:fromXScale="1.5"  
  8.         android:fromYScale="1.5"  
  9.         android:pivotX="50.0%"  
  10.         android:pivotY="50.0%"  
  11.         android:toXScale="1.0"  
  12.         android:toYScale="1.0" />  
  13.   
  14.     <alpha  
  15.         android:duration="@android:integer/config_mediumAnimTime"  
  16.         android:fromAlpha="0.4"  
  17.         android:toAlpha="1.0" />  
  18.   
  19. </set>  
<?xml version="1.0" encoding="UTF-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator" >

    <scale
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromXScale="1.5"
        android:fromYScale="1.5"
        android:pivotX="50.0%"
        android:pivotY="50.0%"
        android:toXScale="1.0"
        android:toYScale="1.0" />

    <alpha
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromAlpha="0.4"
        android:toAlpha="1.0" />

</set>

4.back_exit.xml

  1. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     android:interpolator="@android:anim/decelerate_interpolator" >  
  3.   
  4.     <scale  
  5.         android:duration="@android:integer/config_mediumAnimTime"  
  6.         android:fromXScale="1.0"  
  7.         android:fromYScale="1.0"  
  8.         android:pivotX="50.0%"  
  9.         android:pivotY="50.0%"  
  10.         android:toXScale="0.4"  
  11.         android:toYScale="0.4" />  
  12.   
  13.     <alpha  
  14.         android:duration="@android:integer/config_mediumAnimTime"  
  15.         android:fromAlpha="1.0"  
  16.         android:toAlpha="0.0" />  
  17.   
  18. </set>  
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator" >

    <scale
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromXScale="1.0"
        android:fromYScale="1.0"
        android:pivotX="50.0%"
        android:pivotY="50.0%"
        android:toXScale="0.4"
        android:toYScale="0.4" />

    <alpha
        android:duration="@android:integer/config_mediumAnimTime"
        android:fromAlpha="1.0"
        android:toAlpha="0.0" />

</set>

     然后在res/values/styles下面进行引用4个anim.xml文件

  1. <style name="ThemeActivity" mce_bogus="1" parent="android:Theme.Light">  
  2.         <item name="android:windowAnimationStyle">@style/AnimationActivity</item>  
  3.     </style>  
  4.   
  5.     <style name="AnimationActivity" mce_bogus="1" parent="@android:style/Animation.Activity">  
  6.         <item name="android:activityOpenEnterAnimation">@anim/anim_enter</item>  
  7.         <item name="android:activityOpenExitAnimation">@anim/anim_exit</item>  
  8.         <item name="android:activityCloseEnterAnimation">@anim/back_enter</item>  
  9.         <item name="android:activityCloseExitAnimation">@anim/back_exit</item>  
  10.     </style>  
<style name="ThemeActivity" mce_bogus="1" parent="android:Theme.Light">
        <item name="android:windowAnimationStyle">@style/AnimationActivity</item>
    </style>

    <style name="AnimationActivity" mce_bogus="1" parent="@android:style/Animation.Activity">
        <item name="android:activityOpenEnterAnimation">@anim/anim_enter</item>
        <item name="android:activityOpenExitAnimation">@anim/anim_exit</item>
        <item name="android:activityCloseEnterAnimation">@anim/back_enter</item>
        <item name="android:activityCloseExitAnimation">@anim/back_exit</item>
    </style>



最后在AndroidManifest.xml下面的application里面的theme定义ThemeActivity

  1. android:theme="@style/ThemeActivity"   
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值