Acitivity进入退出动画效果的两种实现
以前做项目的时候一直没有注意过activity切换动画的问题,一方面因为没有人要求,一方面因为自己还没能静下心来好好学习。现在把这个问题弄清楚了,拿出来分享下。自己也做个总结。
我这里说的两种实现一种是通过调用overridePendingTransition方式指定将要打开的activity的动画和当前activity的退出动画;另一种是我昨天在做dialog进入退出时提出的想法,通过style来指定某个activity的进入退出的动画效果。
先说第一种实现方式:
overridePendingTransition方法的作用就是指定将要打开的Activity的动画和当前Activity的退出动画
谷歌官网上说,该方法应该在调用startActivity()或者finish()之后立即调用
overridePendingTransition方法的第一个参数enterAnim是指进入Activity的动画,第二个参数exitAnim是指当前Activity的退出动画,比如说我代码这么写:
- Intent i = new Intent(MainActivity.this, MainActivity2.class);
- startActivity(i);
- overridePendingTransition(R.anim.enter, R.anim.exit);
我的MainActivity会执行R.anim.exit动画,被打开的MainActivity2会执行R.anim.enter动画。
finish的时候调用:
- this.finish();
- overridePendingTransition(R.anim.enter, R.anim.exit);
我是在刚刚打开的MainActivity2里面执行的这段代码,所以MainAcivity2会执行R.anim.exit动画,而MainActivity将重新获得焦点显示出来,将执行R.anim.enter动画。
因为以前对overridePendingTransition实现进入退出动画一直处于混乱状态,所以第一种方法啰嗦的多了点。
R.anim.enter(从左侧进入)
- <?xml version="1.0" encoding="utf-8"?>
- <set xmlns:android="http://schemas.android.com/apk/res/android" >
- <translate
- android:duration="2000"
- android:fromXDelta="-100%p"
- android:toXDelta="0%p" />
- </set>
R.anim.exit(从右侧退出)
- <?xml version="1.0" encoding="utf-8"?>
- <set xmlns:android="http://schemas.android.com/apk/res/android" >
- <translate
- android:duration="2000"
- android:fromXDelta="0%p"
- android:toXDelta="100%p" />
- </set>
第二中发法实现Activity动画效果主要是通过style进行指定。
可以写一个如下的style
- <style name="mystyle" parent="android:Animation">
- <item name="@android:windowEnterAnimation">@anim/enter</item>
- <item name="@android:windowExitAnimation">@anim/exit</item>
- </style>
然后通过window.setWindowAnimations方法指定给当前的Activity,这样,当这个Activity进入退出的时候就会分别执行windowEnterAnimation和windowExitAnimation Item指定的anim了。具体的enter和exit动画和上面的一样。
设置代码和设置dialog进入退出一样:
- getWindow().setWindowAnimations(R.style.mystyle);
另外还可以通过在配置文件中通过给Ativity指定thame来将动画效果设置给Activity
代码如下:
- <style name="AppTheme" parent="AppBaseTheme">
- <item name="android:windowAnimationStyle">@style/mystyle</item>
- </style>
- <style name="mystyle" parent="android:Animation">
- <item name="@android:windowEnterAnimation">@anim/enter</item>
- <item name="@android:windowExitAnimation">@anim/exit</item>
- </style>
- //配置文件中这么写的
- <activity
- android:name="com.example.activityanimdemo.MainActivity2"
- android:theme="@style/AppTheme" >
- </activity>
除了可以通过windowEnterAnimation和windowExitAnimation Item指定进入退出动画效果,还可以通过以下Item来指定
- <item name="android:activityOpenEnterAnimation"></item>
- <item name="android:activityOpenExitAnimation"></item>
- <item name="android:activityCloseEnterAnimation"></item>
- <item name="android:activityCloseExitAnimation"></item>
另外,我试了下这同时用overridePendingTransition指定Activity的动画和用style指定Activity的动画,发现他们指定的动画会同时执行。