利用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. }  

 

 

 



    本文转自 一点点征服   博客园博客,原文链接:http://www.cnblogs.com/ldq2016/p/6248906.html,如需转载请自行联系原作者


相关文章
|
4月前
|
XML Android开发 数据格式
Android 中如何设置activity的启动动画,让它像dialog一样从底部往上出来
在 Android 中实现 Activity 的对话框式过渡动画:从底部滑入与从顶部滑出。需定义两个 XML 动画文件 `activity_slide_in.xml` 和 `activity_slide_out.xml`,分别控制 Activity 的进入与退出动画。使用 `overridePendingTransition` 方法在启动 (`startActivity`) 或结束 (`finish`) Activity 时应用这些动画。为了使前 Activity 保持静止,可定义 `no_animation.xml` 并在启动新 Activity 时仅设置新 Activity 的进入动画。
93 12
|
容器
Fragment——底部导航栏的实现
本节开始我们会讲解一些Fragment在实际开发中的一些实例!而本节给大家讲解的是底部导航栏的实现!而基本的底部导航栏方法有很多种,比如全用TextView做,或者用RadioButton,又或者使用TabLayout + RadioButton,当然复杂的情况还是得走外层套布局的方法!本节我们用TextView来做一个底部导航栏的效果,也熟悉下Fragment的使用!
112 0
|
XML Java 数据格式
Fragment底部导航栏
一个页面以微信为例,从上到下依次是状态栏,Activity顶部导航栏,Fragment,Activity底部导航栏。 每点击一个底部导航栏都会replace另一个Fragment。
72 0
|
Java Android开发 Kotlin
Android 自定义加载动画Dialog弹窗
Android 自定义加载动画Dialog弹窗
338 0
Android 自定义加载动画Dialog弹窗
|
Android开发
Android Reveal圆形Activity转场动画
一、效果 图片较大无法上传~~ 地址:https://user-gold-cdn.xitu.io/2018/11/2/166d4b91aecdf577?imageslim 二、知识点 CircularReveal动画、透明主题、转场动画(非必须) 三、方案 假设有两个Activity A和B。
2044 0
|
Android开发 UED 数据格式
Android自定义组合控件---教你如何自定义下拉刷新和左滑删除
版权声明:本文为博主原创文章,转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/51234574 绪论 最近项目里面用到了下...
854 0