Activity启动从底部向上滑动出现,关闭的时候从顶部向下滑动消失的动画实现---Android提高篇


Activity启动从底部向上滑动出现,

关闭的时候从顶部向下滑动消失的动画实现


文 | 莫若吻     


1.简析实现Activity启动和关闭动画

打开app都有启动动画,在打开一个新窗体时,用有个过渡动画,户感觉体验效果很好,不会觉得很突然就冒出一个窗体,而实现Android 的Activity启动和关闭动画其实很简单,主要是通过设置两个动画效果,和一个overridePendingTransition(int enterAnim,int ExitAnim)方法就完全可以解决。

Activity的切换动画指的是从一个activity跳转到另外一个activity时的动画。


2.overridePendingTransition()方法简介

作用

一是设置第一个activity退出时的动画;二是设置第二个activity进入时的动画;

说明:

overridePendingTransition()方法有两个参数,一个参数是第一个activity进入时的动画,另外一个参数则是第二个activity退出时的动画。

Note:

1)必需紧挨着startActivity()或者finish()函数之后调用"

2)只在android2.0以及以上版本上适用  

总结:有时候overridePendingTransition 这个函数会不起作用,大概是以下三个方面的原因:

1)android系统版本2.0以下,这个没办法,想其他办法解决切换动画吧。

2)在ActivityGroup等的嵌入式Activity中;用如下方法就可以解决了:

  this.getParent().overridePendingTransition()

3)在一个Activity的内部类中,或者匿名类中,这时候用handler来解决。

4)手机的显示动画效果被人为或者其他方式给关闭了 现在打开即可 设置->显示->显示动画效果


3.实现过程:

以Activity启动从底部向上滑动出现,关闭的时候从顶部向下滑动消失的动画实现为例。

1)需要配置2个动画XML,一个是启动动画,一个是结束动画。

2)用方法overridePendingTransition()调用启动Activity的动画和关闭Activity的动画。

3)(可选)不需要状态标题栏出现时需要设置activity标题栏透明,在androidmanifest.xml里配置

android:theme="@android:style/Theme.Translucent"即可。


4.部分主要实现代码

(注:具体动画的设置,看不懂的同学大家自行找资料学习,很简单的。)

开启动画activity_open.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:fromYDelta="100%p"
        android:toYDelta="25"
        android:duration="500"
        />
</set>

结束动画:activity_close.xml

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

设置启动activity动画:

注:只是部分主要代码,目的是告诉大家如何使用)

startActivity(Activity.class);
activity.overridePendingTransition(R.anim.activity_open,0);

设置关闭activity动画

注:两种位置,其实道理都是一样的)

finish();
//关闭activity动画显示
this.overridePendingTransition(0, R.anim.activity_close);

或者:

@Override
public void finish() {    
    super.finish();
    //关闭activity动画显示
    this.overridePendingTransition(0, R.anim.activity_close);
}



  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值