Activity切换的动画

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>
然后就是在res/anim文件夹中定义对应的动画文件default_anim_in,anim_stay,  default_anim_out。


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" >
这样就可以了。在activity中定义的方法同aplication,在application中定义会作用在全部activity,如果在activity中也定义了一个动画的话就会覆盖application中定义的动画。


下面附送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!!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一些常见的activity切换动画代码: 1. 淡入淡出动画: 在styles.xml中定义: ``` <style name="Fade"> <item name="android:windowEnterAnimation">@android:anim/fade_in</item> <item name="android:windowExitAnimation">@android:anim/fade_out</item> </style> ``` 在AndroidManifest.xml中应用: ``` <activity android:name=".MyActivity" android:theme="@style/Fade" /> ``` 2. 左右滑动动画: 在styles.xml中定义: ``` <style name="Slide"> <item name="android:windowEnterAnimation">@anim/slide_right_in</item> <item name="android:windowExitAnimation">@anim/slide_left_out</item> </style> ``` 在AndroidManifest.xml中应用: ``` <activity android:name=".MyActivity" android:theme="@style/Slide" /> ``` slide_right_in.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="100%" android:toXDelta="0%" android:duration="300" /> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="300" /> </set> ``` slide_left_out.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0%" android:toXDelta="-100%" android:duration="300" /> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="300" /> </set> ``` 3. 缩放动画: 在styles.xml中定义: ``` <style name="Zoom"> <item name="android:windowEnterAnimation">@anim/zoom_in</item> <item name="android:windowExitAnimation">@anim/zoom_out</item> </style> ``` 在AndroidManifest.xml中应用: ``` <activity android:name=".MyActivity" android:theme="@style/Zoom" /> ``` zoom_in.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/decelerate_interpolator"> <scale android:fromXScale="0.0" android:toXScale="1.0" android:fromYScale="0.0" android:toYScale="1.0" android:pivotX="50%" android:pivotY="50%" android:duration="300" /> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="300" /> </set> ``` zoom_out.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/accelerate_interpolator"> <scale android:fromXScale="1.0" android:toXScale="0.0" android:fromYScale="1.0" android:toYScale="0.0" android:pivotX="50%" android:pivotY="50%" android:duration="300" /> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="300" /> </set> ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值