利用Theme自定义Activity间的切换动画

转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/22990643

大多Android系统默认Activity间的动画切换效果为,右边滑入,左边滑出;有时候我们的需求可能是要求所有Activity的切换为淡入淡出的效果,这时候就可能需要改变一下默认的切换风格。

下面开始实现:

首先在res文件夹下建立anim文件夹,然后在里面建立fade_in.xml和fade_out.xml两个动画资源

fade_in.xml

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <alpha xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:duration="300"  
  4.     android:fromAlpha="0.0"  
  5.     android:interpolator="@android:anim/accelerate_interpolator"  
  6.     android:toAlpha="1.0" />  
fade_ out .xml

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <alpha xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:duration="300"  
  4.     android:fromAlpha="1.0"  
  5.     android:interpolator="@android:anim/accelerate_interpolator"  
  6.     android:toAlpha="0.0" />  
然后在values文件夹下的styles.xml中的resources标签内写:

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <style name="Anim_fade" parent="android:Theme.NoTitleBar">  
  2.        <item name="android:windowAnimationStyle">@style/fade</item>  
  3.    </style>  
  4.   
  5.    <style name="fade" parent="@android:style/Animation.Activity">  
  6.        <item name="android:activityOpenEnterAnimation">@anim/fade_in</item>  
  7.        <item name="android:activityOpenExitAnimation">@anim/fade_out</item>  
  8.        <item name="android:activityCloseEnterAnimation">@anim/fade_in</item>  
  9.        <item name="android:activityCloseExitAnimation">@anim/fade_out</item>  
  10.    </style>  

最后一步在AndroidManifest.xml中的Activity的声明上加入android:theme="@style/Anim_fade"

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     package="com.example.customanimationforactivity"  
  4.     android:versionCode="1"  
  5.     android:versionName="1.0" >  
  6.   
  7.     <uses-sdk  
  8.         android:minSdkVersion="10"  
  9.         android:targetSdkVersion="10" />  
  10.   
  11.     <application  
  12.         android:allowBackup="true"  
  13.         android:icon="@drawable/ic_launcher"  
  14.         android:label="@string/app_name"  
  15.         android:theme="@android:style/Theme.NoTitleBar" >  
  16.         <activity  
  17.             android:name="com.example.customanimationforactivity.MainActivity"  
  18.             android:label="@string/app_name"  
  19.             android:theme="@style/Anim_fade" >  
  20.             <intent-filter>  
  21.                 <action android:name="android.intent.action.MAIN" />  
  22.                 <category android:name="android.intent.category.LAUNCHER" />  
  23.             </intent-filter>  
  24.         </activity>  
  25.         <activity android:name=".AppActivity" android:theme="@style/Anim_fade" >  
  26.         </activity>  
  27.     </application>  
  28.   
  29. </manifest>  
贴下Splash Activity的代码:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.example.customanimationforactivity;  
  2.   
  3. import android.app.Activity;  
  4. import android.content.Intent;  
  5. import android.os.Bundle;  
  6. import android.os.Handler;  
  7.   
  8. public class MainActivity extends Activity  
  9. {  
  10.   
  11.     private Handler handler = new Handler();  
  12.   
  13.     @Override  
  14.     protected void onCreate(Bundle savedInstanceState)  
  15.     {  
  16.         super.onCreate(savedInstanceState);  
  17.         setContentView(R.layout.activity_main);  
  18.         handler.postDelayed(new Runnable()  
  19.         {  
  20.             @Override  
  21.             public void run()  
  22.             {  
  23.                 Intent intent = new Intent(MainActivity.this, AppActivity.class);  
  24.                 startActivity(intent);  
  25.                 finish();  
  26.             }  
  27.         }, 1000);  
  28.   
  29.     }  
  30.   
  31. }  

源码下载,点击这里


关于Dialog和Activity的style的深入理解


结合该事例的下载地址:http://www.cnblogs.com/Jaylong/archive/2012/08/30/activity.html
<!-- 微博 -->
     <style name= "weibosdk_ContentOverlay"  parent= "android:style/Theme.Dialog" >
         <item name= "android:windowNoTitle" > true </item> <span style= "background-color: #00ff00;" >没有标题
</span>        <item name= "android:windowIsTranslucent" > true </item> <span style= "background-color: #00ff00;" >透明
</span>        <item name= "android:windowBackground" > @color /weibosdk_transparent</item> <span style= "background-color: #00ff00;" >窗口背景色
</span>        <item name= "android:windowAnimationStyle" > @android :style/Animation.Translucent</item> <span style= "background-color: #00ff00;" >重要,Dialog进出的显示动画
</span>        <item name= "android:windowContentOverlay" > @null </item> <span style= "background-color: #00ff00;" >是否有覆盖
</span>        <item name= "android:backgroundDimEnabled" > false </item> <span style= "background-color: #00ff00;" >dialog的背景是否昏暗
</span>    </style>

 以上是自定义Dialgog可以使用自定义样式:

关于<item name="android:windowAnimationStyle">@android:style/Animation.Translucent</item> 重要,Dialog进出的显示动画要特别注意,可以自定义Dialog进出的动画,但是item的名字必须和下面的一样,以确定Android系统能够认识出来。

<style name= "Animation.Translucent" >
         <item name= "windowEnterAnimation" > @anim /translucent_enter</item>
         <item name= "windowExitAnimation" > @anim /translucent_exit</item>
     </style>

 ----------------------------------------------

Activity 自定义样式:

<style name= "ThemeActivity" >
      <item name= "android:windowAnimationStyle" > @style /AnimationActivity</item>
      <item name= "android:windowNoTitle" > true </item>
      <item name= "android:windowFullscreen" > true </item>
      <item name= "android:windowContentOverlay" > @null </item>
      <item name= "android:windowIsTranslucent" > true </item>
  </style>

 同样的每个item对应的name不能变,以保证Android系统能够辨认出来。

<style name= "AnimationActivity"  parent= "@android:style/Animation.Activity" >
         <item name= "android:activityOpenEnterAnimation" > @anim /slideinright</item> <span style= "background-color: #00ff00;" >第一次创建新Activity是调用的动画
</span>        <item name= "android:activityCloseExitAnimation" > @anim /slideoutright</item> <span style= "background-color: #00ff00;" >调用finish关闭该Activity是调用的动画
</span>        <item name= "android:activityOpenExitAnimation" > @anim /slideoutleft</item>   <span style= "background-color: #00ff00;" >activity还没有finish()下退出效果</span>
         <item name= "android:activityCloseEnterAnimation" > @anim /slideinleft</item> <span style= "background-color: #00ff00;" > 上一个activity返回进入效果 
</span><br>  </style>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值