android统一添加activity切换动画

android统一添加activity切换动画

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

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

使用两种方法的前提都是需要准备动画效果文件:
slide_in_form_left.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="200"
        android:fromXDelta="-100%p"
        android:toXDelta="0" />
</set>
slide_in_for_right.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="200"
        android:fromXDelta="100%p"
        android:toXDelta="0" />
</set>
slide_out_to_left.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:duration="200"
        android:fromXDelta="0"
        android:toXDelta="-100%p" />
</set>
slide_out_to_right.xml
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="200"
        android:fromXDelta="0"
        android:toXDelta="100%p" />
</set>

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

第二种方式配置,在开发中一般都会配置基类BaseActivity,让所有的Activity去继承BaseActivity方便管理
  1. 在BaseActivity中OnCreate()启动
    switch (STATE) {
                    case LEFT:
                        //输入,退出  的界面
                        overridePendingTransition(R.anim.left_in, R.anim.left_out);
                        break;
                    case RIGHT:
                        overridePendingTransition(R.anim.right_in, R.anim.right_out);
                        break;
                    case TOP:
                        overridePendingTransition(R.anim.top_in, R.anim.top_out);
                        break;
                    case BOTTOM:
                        overridePendingTransition(R.anim.bottom_in, R.anim.bottom_out);
                        break;
                    case SCALE:
                        overridePendingTransition(R.anim.scale_in, R.anim.scale_out);
                        break;
                    case FADE:
                        overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
                        break;
                }
  2. finish()关闭
    
    @Override
        public void finish() {
            super.finish();
                switch (STATE) {
                    case LEFT:
                        overridePendingTransition(R.anim.left_in, R.anim.left_out);
                        break;
                    case RIGHT:
                        overridePendingTransition(R.anim.right_in, R.anim.right_out);
                        break;
                    case TOP:
                        overridePendingTransition(R.anim.top_in, R.anim.top_out);
                        break;
                    case BOTTOM:
                        overridePendingTransition(R.anim.bottom_in, R.anim.bottom_out);
                        break;
                    case SCALE:
                        overridePendingTransition(R.anim.scale_in, R.anim.scale_out);
                        break;
                    case FADE:
                        overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
                        break;
                }
            
        }






参考灵感:
https://github.com/GcsSloop/SloopBlog/blob/master
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

caption_deng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值