Activity启动从底部向上滑动出现,
关闭的时候从顶部向下滑动消失的动画实现
1.简析实现Activity启动和关闭动画
打开app都有启动动画,在打开一个新窗体时,用有个过渡动画,户感觉体验效果很好,不会觉得很突然就冒出一个窗体,而实现Android 的Activity启动和关闭动画其实很简单,主要是通过设置两个动画效果,和一个overridePendingTransition(int enterAnim,int ExitAnim)方法就完全可以解决。
(Activity的切换动画指的是从一个activity跳转到另外一个activity时的动画。)
2.overridePendingTransition()方法简介
作用:
一是设置第一个activity退出时的动画;二是设置第二个activity进入时的动画;
说明:
overridePendingTransition()方法有两个参数,一个参数是第一个activity进入时的动画,另外一个参数则是第二个activity退出时的动画。
Note:
1)必需紧挨着startActivity()或者finish()函数之后调用"
2)只在android2.0以及以上版本上适用
总结:有时候overridePendingTransition 这个函数会不起作用,大概是以下三个方面的原因:
1)android系统版本2.0以下,这个没办法,想其他办法解决切换动画吧。
2)在ActivityGroup等的嵌入式Activity中;用如下方法就可以解决了:
this.getParent().overridePendingTransition()
3)在一个Activity的内部类中,或者匿名类中,这时候用handler来解决。
4)手机的显示动画效果被人为或者其他方式给关闭了 现在打开即可 设置->显示->显示动画效果
3.实现过程:
以Activity启动从底部向上滑动出现,关闭的时候从顶部向下滑动消失的动画实现为例。
1)需要配置2个动画XML,一个是启动动画,一个是结束动画。
2)用方法overridePendingTransition()调用启动Activity的动画和关闭Activity的动画。
3)(可选)不需要状态标题栏出现时需要设置activity标题栏透明,在androidmanifest.xml里配置
android:theme="@android:style/Theme.Translucent"即可。
4.部分主要实现代码
(注:具体动画的设置,看不懂的同学大家自行找资料学习,很简单的。)
开启动画activity_open.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromYDelta="100%p" android:toYDelta="25" android:duration="500" /> </set>
结束动画:activity_close.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromYDelta="0" android:toYDelta="100%p" android:duration="500" /> </set>
设置启动activity动画:
(注:只是部分主要代码,目的是告诉大家如何使用)
startActivity(Activity.class); activity.overridePendingTransition(R.anim.activity_open,0);
设置关闭activity动画
(注:两种位置,其实道理都是一样的)
finish(); //关闭activity动画显示 this.overridePendingTransition(0, R.anim.activity_close);
或者:
@Override public void finish() { super.finish(); //关闭activity动画显示 this.overridePendingTransition(0, R.anim.activity_close); }