android中的所有activity间动画跳转

本文介绍如何为所有Activity设置统一的自定义动画效果,包括进入和退出动画,并通过修改AndroidManifest.xml文件来应用这些动画。

在之前的一篇博客里介绍过activity间动画跳转的问题,但是真正做软件发现并不能满足我们的要求,因为使用overridePendingTransition(int enterAnim, intexitAnim)这个函数只能实现进入另一个activity的动画,当另一个activity退出时,还是使用的系统动画。所以在这里讲一下怎么设置所有activity的动画跳转和退出跳转。其实有些软件已经这样做了,比如我们都比较熟悉的大众点评网。

下面我们通过一个实例来看一下怎么实现所有activity动画跳转,这里我们不妨就模仿下大众点评网activity的动画跳转。

首先在layout/anim新建 anim_enter.xml

[html] view plain copy
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <setandroid:interpolator="@android:anim/decelerate_interpolator"
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <scaleandroid:duration="@android:integer/config_mediumAnimTime"android:pivotX="69.99999%"android:pivotY="100.0%"android:fromXScale="0.0"android:toXScale="1.0"android:fromYScale="0.0"android:toYScale="1.0"/>
  5. <alphaandroid:duration="@android:integer/config_mediumAnimTime"android:fromAlpha="0.0"android:toAlpha="1.0"/>
  6. </set>
anim_exit.xml
[html] view plain copy
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <setandroid:interpolator="@android:anim/accelerate_interpolator"
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <scaleandroid:duration="@android:integer/config_mediumAnimTime"android:pivotX="69.99999%"android:pivotY="100.0%"android:fromXScale="1.0"android:toXScale="0.0"android:fromYScale="1.0"android:toYScale="0.0"/>
  5. <alphaandroid:duration="@android:integer/config_mediumAnimTime"android:fromAlpha="1.0"android:toAlpha="0.0"/>
  6. </set>
上面的两个xml分别对应overridePendingTransition(int enterAnim, int exitAnim) 中的进入和退出动画

接下来定义当另一个activity退出时的动画效果,back_enter.xml

[html] view plain copy
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <setandroid:interpolator="@android:anim/decelerate_interpolator"
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <scaleandroid:duration="@android:integer/config_mediumAnimTime"android:pivotX="50.0%"android:pivotY="50.0%"android:fromXScale="1.5"android:toXScale="1.0"android:fromYScale="1.5"android:toYScale="1.0"/>
  5. <alphaandroid:duration="@android:integer/config_mediumAnimTime"android:fromAlpha="0.4"android:toAlpha="1.0"/>
  6. </set>

back_exit.xml

[html] view plain copy
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <setandroid:interpolator="@android:anim/decelerate_interpolator"
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <scaleandroid:duration="@android:integer/config_mediumAnimTime"android:pivotX="50.0%"android:pivotY="50.0%"android:fromXScale="1.0"android:toXScale="0.4"android:fromYScale="1.0"android:toYScale="0.4"/>
  5. <alphaandroid:duration="@android:integer/config_mediumAnimTime"android:fromAlpha="1.0"android:toAlpha="0.0"/>
  6. </set>

进入和退出动画效果我们已经定义好了,接下来需要定义样式,以前我们设置动画效果都是写在activity中,只是对单个activity定义动画。现在我们对所有的activity定义动画效果,我们不妨设想一下应该定义一个样式,在所有包裹activity的地方引入样式。这样我们就想到了AndroidManifest.xml里的application 了,他里面生命所有的activity,明白了这些就好办了。

接下来我们需要在String.xml声明动画的样式

[html] view plain copy
  1. <stylename="ThemeActivity"mce_bogus="1">
  2. <itemname="android:windowAnimationStyle">@style/AnimationActivity</item>
  3. <itemname="android:windowNoTitle">true</item>
  4. lt;/style>
  5. <stylename="AnimationActivity"parent="@android:style/Animation.Activity"mce_bogus="1">
  6. <itemname="android:activityOpenEnterAnimation">@anim/anim_enter</item>
  7. <itemname="android:activityOpenExitAnimation">@anim/anim_exit</item>
  8. <itemname="android:activityCloseEnterAnimation">@anim/back_enter</item>
  9. <itemname="android:activityCloseExitAnimation">@anim/back_exit</item>
  10. lt;/style>

然后在 AndroidManifest.xml里声明样式

[html] view plain copy
  1. <application
  2. android:icon="@drawable/ic_launcher"<spanstyle="color:#FF0000;">android:theme="@style/ThemeActivity"</span>
  3. android:label="@string/app_name">
  4. <activity
  5. android:label="@string/app_name"
  6. android:name=".GlobalAnimationActivity">
  7. <intent-filter>
  8. <actionandroid:name="android.intent.action.MAIN"/>
  9. <categoryandroid:name="android.intent.category.LAUNCHER"/>
  10. </intent-filter>
  11. </activity>
  12. <activityandroid:name=".OtherActivity"></activity>
  13. </application>


OK,这样就实现了大众点评网activity的动画跳转,大家自己体验下吧。

最近公司项目确实是比较忙,博客里有些朋友留言需要源代码,也没有一一发,我把大部分都已经上传到群共享里了,麻烦大家自己下载吧!

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值