Activity去掉默认的动画效果方法:
1.重写Activity的Them中的windowAnimationStyle相关属性,并保存在res/values/styles.xml
Java code
<?xml version="1.0" encoding="utf-8"?><resources><style name="Theme" parent="android:Theme"><item name="android:windowAnimationStyle">@style/Animation</item></style><style name="Animation"><item name="android:activityOpenEnterAnimation">@null</item><item name="android:activityOpenExitAnimation">@null</item><item name="android:activityCloseEnterAnimation">@null</item><item name="android:activityCloseExitAnimation">@null</item><item name="android:taskOpenEnterAnimation">@null</item><item name="android:taskOpenExitAnimation">@null</item><item name="android:taskCloseEnterAnimation">@null</item><item name="android:taskCloseExitAnimation">@null</item><item name="android:taskToFrontEnterAnimation">@null</item><item name="android:taskToFrontExitAnimation">@null</item><item name="android:taskToBackEnterAnimation">@null</item><item name="android:taskToBackExitAnimation">@null</item></style>
2.在不想有动画的Activity上设置此属性即可 <activity android:name=".XXXXXX" android:label="@string/app_name"android:screenOrientation="nosensor" android:theme="@style/Theme"></resources>
Activity的切换动画指的是从一个activity跳转到另外一个activity时的动画。
它包括两个部分:
一部分是第一个activity退出时的动画;
另外一部分时第二个activity进入时的动画;
在Android的2.0版本之后,有了一个函数来帮我们实现这个动画。这个函数就是
overridePendingTransition
这个函数有两个参数,一个参数是第一个activity退出时的动画,另外一个参数则是第二个activity进入时的动画。
这里需要特别说明的是,关于overridePendingTransition这个函数,有两点需要主意:
1.它必需紧挨着startActivity()或者finish()函数之后调用
2.它只在android2.0以及以上版本上适用
实现Acitvity之间跳转的方式有两种。
一、在AndroidManifest中定义。
1、现在res/values/styles.xml中加上一个style,如下
1
2
3
4
|
<style name=
"AppTheme"
mce_bogus=
"1"
parent=
"@android:style/Theme.Light"
>
<item name=
"android:windowAnimationStyle"
>
@style
/default_animation</item>
<item name=
"android:windowNoTitle"
>
true
</item>
</style>
|
<item name="android:windowNoTitle">true</item>这一句是要隐藏标题栏,因为动画的范围是包括标题栏的,这个可选。
<item name="android:windowAnimationStyle">@style/default_animation</item>作用就是指定一个动画文件。所以要在定义一个style(同样在res/values/styles.xml,也可以另外新建一个xml)
定义的style如下
1
2
3
4
5
6
7
|
<!-- 默认Activity跳转动画 -->
<style name=
"default_animation"
mce_bogus=
"1"
parent=
"@android:style/Animation.Activity"
>
<item name=
"android:activityOpenEnterAnimation"
>
@anim
/default_anim_in</item>
<item name=
"android:activityOpenExitAnimation"
>
@anim
/anim_stay</item>
<item name=
"android:activityCloseEnterAnimation"
>
@anim
/anim_stay</item>
<item name=
"android:activityCloseExitAnimation"
>
@anim
/default_anim_out</item>
</style>
|
4个item分别代表
Activity A跳转到Activity B时Activity B进入动画;
Activity A跳转到Activity B时Activity A退出动画;
Activity B返回Activity A时Activity A的进入动画
Activity B返回Activity A时ActivityB的退出动画
最后一步就是在AndroidManifest中加上这些动画。
1
2
3
4
|
<application
android:icon=
"@drawable/logo"
android:label=
"@string/app_name"
android:theme=
"@style/AppTheme"
>
|
下面附送default_anim_in,anim_stay,default_anim_out三个动画文件(实现QQ的跳转动画——渐变切换)。
default_anim_in
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<?xml version=
"1.0"
encoding=
"utf-8"
?>
<set xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<scale
android:duration=
"200"
android:fromXScale=
"0.7"
android:fromYScale=
"0.7"
android:interpolator=
"@android:anim/accelerate_decelerate_interpolator"
android:pivotX=
"50%"
android:pivotY=
"50%"
android:toXScale=
"1"
android:toYScale=
"1"
/>
<alpha
android:duration=
"200"
android:fromAlpha=
"0"
android:toAlpha=
"1.0"
/>
</set>
|
default_anim_out
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<?xml version=
"1.0"
encoding=
"utf-8"
?>
<set xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<scale
android:duration=
"200"
android:fromXScale=
"1"
android:fromYScale=
"1"
android:interpolator=
"@android:anim/accelerate_decelerate_interpolator"
android:pivotX=
"50%"
android:pivotY=
"50%"
android:toXScale=
"0.7"
android:toYScale=
"0.7"
/>
<alpha
android:duration=
"200"
android:fromAlpha=
"1"
android:toAlpha=
"0"
/>
</set>
|
anim_stay
1
2
3
4
5
6
7
8
9
|
<?xml version=
"1.0"
encoding=
"utf-8"
?>
<set xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<translate
android:duration=
"500"
android:fromXDelta=
"0"
android:fromYDelta=
"0"
android:toXDelta=
"0"
android:toYDelta=
"0"
/>
</set>
|
要实现跳转动画同样可以在代码中哦跟实现。
Activity A跳转到Activity B,要在startActivity(intent)后面加上overridePendingTransition(R.anim.anim_in, R.anim.anim_out);
Activity B返回Activity A,要在finish()后面加上overridePendingTransition(R.anim.anim_in, R.anim.anim_out);
anim_in是进入的Activity的动画,anim_out是退出的Activity的动画。
over!!!!