android统一添加activity切换动画

(转载)http://blog.csdn.net/caption_deng/article/details/50936418

android统一添加activity切换动画

  在告别2015最后一天的时候就决定写写博客,由于工作忙碌一拖就是几个月过去了,是时候来聊聊人生谈谈理想。
----2016-03-20 里程碑
  在实际的应用开发过程中各种动画效果是必不可少的,这样可以让用户体验到app的流传度和适用度,方便用户快速的熟悉app应用的操作。废话不多说,直接开播。。。

实现activity界面切换动画效果有两种方式:
1.styles.xml编写动画主题,在AndroidManifest.xml里面使用。
2.在activity的onCreate()和finish() 里面调用overridePendingTransition函数

使用两种方法的前提都是需要准备动画效果文件:
slide_in_form_left.xml
[html] view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android">  
  3.   
  4.     <translate  
  5.         android:duration="200"  
  6.         android:fromXDelta="-100%p"  
  7.         android:toXDelta="0" />  
  8. </set>  
slide_in_for_right.xml
[html] view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android">  
  3.   
  4.     <translate  
  5.         android:duration="200"  
  6.         android:fromXDelta="100%p"  
  7.         android:toXDelta="0" />  
  8. </set>  
 slide_out_to_left.xml
[html] view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android">  
  3.   
  4.     <translate  
  5.         android:duration="200"  
  6.         android:fromXDelta="0"  
  7.         android:toXDelta="-100%p" />  
  8. </set>  
 slide_out_to_right.xml
[html] view plain copy
  1. <set xmlns:android="http://schemas.android.com/apk/res/android">  
  2.     <translate  
  3.         android:duration="200"  
  4.         android:fromXDelta="0"  
  5.         android:toXDelta="100%p" />  
  6. </set>  

写完动画效果文件后,就按照第一种方式配置:
  1. styles.xml 文件配置启动关闭效果动画
    [html] view plain copy
    1. <!-- 界面切换动画 -->  
    2.     <style name="animfade" parent="@android:style/Animation.Activity">  
    3.         <item name="android:activityOpenEnterAnimation">@anim/slide_in_from_right</item>  
    4.         <item name="android:activityOpenExitAnimation">@anim/slide_out_to_left</item>  
    5.         <item name="android:activityCloseExitAnimation">@anim/slide_out_to_right</item>  
    6.         <item name="android:activityCloseEnterAnimation">@anim/slide_in_from_left</item>  
    7.     </style>  
    [html] view plain copy
    1. <!-- Base application theme. -->  
    2.     <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">  
    3.         <!-- Customize your theme here. -->  
    4.         <item name="android:windowAnimationStyle">@style/animfade</item>  
    5.     </style>  
  2. 在AndroidManifest.xml配置Theme
    [html] view plain copy
    1. <application  
    2.         android:allowBackup="true"  
    3.         android:icon="@mipmap/icon_logo"  
    4.         android:label="@string/app_name"  
    5.         android:supportsRtl="true"  
    6.         android:theme="@style/AppTheme">  

第二种方式配置,在开发中一般都会配置基类BaseActivity,让所有的Activity去继承BaseActivity方便管理
  1. 在BaseActivity中OnCreate()启动
    [java] view plain copy
    1. switch (STATE) {  
    2.                 case LEFT:  
    3.                     //输入,退出  的界面  
    4.                     overridePendingTransition(R.anim.left_in, R.anim.left_out);  
    5.                     break;  
    6.                 case RIGHT:  
    7.                     overridePendingTransition(R.anim.right_in, R.anim.right_out);  
    8.                     break;  
    9.                 case TOP:  
    10.                     overridePendingTransition(R.anim.top_in, R.anim.top_out);  
    11.                     break;  
    12.                 case BOTTOM:  
    13.                     overridePendingTransition(R.anim.bottom_in, R.anim.bottom_out);  
    14.                     break;  
    15.                 case SCALE:  
    16.                     overridePendingTransition(R.anim.scale_in, R.anim.scale_out);  
    17.                     break;  
    18.                 case FADE:  
    19.                     overridePendingTransition(R.anim.fade_in, R.anim.fade_out);  
    20.                     break;  
    21.             }  
  2. finish()关闭
    
    1. @Override  
    2.     public void finish() {  
    3.         super.finish();  
    4.             switch (STATE) {  
    5.                 case LEFT:  
    6.                     overridePendingTransition(R.anim.left_in, R.anim.left_out);  
    7.                     break;  
    8.                 case RIGHT:  
    9.                     overridePendingTransition(R.anim.right_in, R.anim.right_out);  
    10.                     break;  
    11.                 case TOP:  
    12.                     overridePendingTransition(R.anim.top_in, R.anim.top_out);  
    13.                     break;  
    14.                 case BOTTOM:  
    15.                     overridePendingTransition(R.anim.bottom_in, R.anim.bottom_out);  
    16.                     break;  
    17.                 case SCALE:  
    18.                     overridePendingTransition(R.anim.scale_in, R.anim.scale_out);  
    19.                     break;  
    20.                 case FADE:  
    21.                     overridePendingTransition(R.anim.fade_in, R.anim.fade_out);  
    22.                     break;  
    23.             }  
    24.           
    25.     }  





参考灵感:
https://github.com/GcsSloop/SloopBlog/blob/master

展开阅读全文

没有更多推荐了,返回首页