Activity切换动画·overridePendingTransition

overridePendingTransition

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

这里需要特别说明的是,关于overridePendingTransition这个函数,有两点需要主意:
1.它必需紧挨着startActivity()或者finish()函数之后调用”
2.它只在android2.0以及以上版本上适用

系统效果
  • 淡入淡出效果

overridePendingTransition(R.anim.fade, R.anim.hold);

  • 放大淡出效果

overridePendingTransition(R.anim.my_scale_action,R.anim.my_alpha_action);

  • 转动淡出效果

overridePendingTransition(R.anim.scale_rotate,R.anim.my_alpha_action);

  • 转动淡出效果

overridePendingTransition(R.anim.scale_translate_rotate,R.anim.my_alpha_action);

  • 左上角展开淡出效果

overridePendingTransition(R.anim.scale_translate,R.anim.my_alpha_action);

  • 压缩变小淡出效果

overridePendingTransition(R.anim.hyperspace_in,R.anim.hyperspace_out);

  • 右往左推出效果

overridePendingTransition(R.anim.push_left_in,R.anim.push_left_out);

  • 下往上推出效果

overridePendingTransition(R.anim.push_up_in,R.anim.push_up_out);

  • 左右交错效果

overridePendingTransition(R.anim.slide_left,R.anim.slide_right);

  • 放大淡出效果

overridePendingTransition(R.anim.wave_scale,R.anim.my_alpha_action);

  • 缩小效果

overridePendingTransition(R.anim.zoom_enter,R.anim.zoom_exit);

  • 上下交错效果

overridePendingTransition(R.anim.slide_up_in,R.anim.slide_down_out);

自定义效果
overridePendingTransition(R.anim.left_in,R.anim.left_out);

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

//这个文件放在res/anim/
<?xml version="1.0" encoding="utf-8"?>
<translate
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="300"
    android:fromXDelta="-100%p"
    android:toXDelta="0"/>
不过有时候overridePendingTransition 这个函数会不起作用,总结下,大概是以下三个方面的原因:
  • android系统版本2.0以下,这个没办法,想其他办法解决切换动画吧。
  • 在ActivityGroup等的嵌入式Activity中,这个比较容易解决,用this.getParent().overridePendingTransition 就可以解决。
  • 在一个Activity的内部类中,或者匿名类中,这时候只好用handler来解决。
  • 手机的显示动画效果被人为或者其他方式给关闭了 现在打开即可 设置->显示->显示动画效果
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值