Android5.0之Activity的转场动画的示例

 更新时间:2017年10月11日 16:47:37   作者:_江南一点雨  
本篇文章主要介绍了Android5.0之Activity的转场动画的示例,非常具有实用价值,需要的朋友可以参考下

Activity的转场动画很早就有,但是太过于单调,样式也不好看,于是Google在Android5.0之后,又推出的新的转场动画,效果还是非常炫的,今天我们一起来看一下。

1.旧转场动画回顾

首先我们还是先来看看在5.0之前如果我们想要在启动Activity时使用动画该怎么做呢?

startActivity(new Intent(this, Main3Activity.class)); 
    overridePendingTransition(R.anim.in,R.anim.out); 

对应的入场和出场动画就是两个补间动画,如下:

入场动画:

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

出场动画:

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

这种动画是针对整个Activity而言的,无法设置Activity中元素的入场/出场动画。如果想要设置Activity中元素的出场/入场动画可以通过设置布局上元素的元素的出/入场动画来实现。但这无疑增加了工作量。

2 5.0之后的转场动画

Android5.0之后Activity的出入场动画总体上来说可以分为两种,一种就是分解、滑动进入、淡入淡出,另外一种就是共享元素动画,下面我们分别就这两种动画进行说明。

2.1 分解、滑动进入、淡入淡出

1.分解

先来看一张效果图:

就是这样一种效果,那我们接下来看看这种效果要怎么实现。

首先,把之前启动Activity的代码改成下面的写法:

复制代码 代码如下:

startActivity(new Intent(this, Main2Activity.class), ActivityOptions.makeSceneTransitionAnimation(this).toBundle()); 
 

添加完成之后,在Main2Activity中设置该Activity的进出场动画即可:

getWindow().setEnterTransition(new Explode().setDuration(2000)); 
getWindow().setExitTransition(new Explode().setDuration(2000)); 

OK,就是这么简单,哦,对了,大家一定要记得在styles.xml文件中添加下面一行代码,表示激活Activity中元素的过渡效果:

<item name="android:windowContentTransitions">true</item> 

2.滑动进入

有了上面的步骤,再设置滑动进入就很简单了,只需要修改Main2Activity中的两行代码即可:

getWindow().setEnterTransition(new Slide().setDuration(2000)); 
getWindow().setExitTransition(new Slide().setDuration(2000)); 

显示效果如下:

3.淡入淡出

Main2Activity修改代码如下:

getWindow().setEnterTransition(new Fade().setDuration(2000)); 
    getWindow().setExitTransition(new Fade().setDuration(2000)); 

显示效果如下:

2.2 共享元素动画

共享元素动画是一个非常神奇的东东,我们先来看看效果:

可能这个Gif动画还不太清晰,我再来解释一下,在MainActivity和Main2Activity里边都有一个Button,只不过一个大一个小,从MainActivity跳转到Main2Activity时,我并没有感觉到Activity的跳转,只是觉得好像第一个页面的Button放大了,同理,当我从第二个页面回到第一个页面时,也好像Button变小了。OK,这就是我们的Activity共享元素。

当两个Activity中有同一个控件的时候,我们便可以采用共享元素动画。

使用共享元素动画的时候,我们需要首先给MainActivity和Main2Activity中的两个button分别添加android:transitionName="mybtn"属性,并且该属性的值要相同,这样系统才知道这两个控件是共享元素。设置完成之后,接下来就是启动Activity的代码了,如下:

复制代码 代码如下:

startActivity(new Intent(this,Main2Activity.class), ActivityOptions.makeSceneTransitionAnimation(this,view,"mybtn").toBundle());

还是上面那种启动方式的重载方法,只不过这里多了两个参数,view表示MainActivity中的共享元素(就是那个Button),第二个参数表示布局文件中transitionAnimation属性的值。OK,就这么简单。

这时有的筒子可能有疑问了,那我如果两个页面中有多个共享元素该怎么办呢?简单,android:transitionName属性还像上面一样设置,然后在启动Activity时我们可以通过Pair.create方法来设置多个共享元素,如下:

startActivity(new Intent(this, Main2Activity.class), 
        ActivityOptions.makeSceneTransitionAnimation(this, Pair.create(((View) iv1),"myiv"), create(((View) textView),"mytv")).toBundle()); 

Pair.create方法中有两个参数,第一个是共享元素的实例(注意要是View类型),第二个参数是该View的transitionAnimation属性的值。

就这么简单,筒子们快速尝试一下吧。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 详解Android自定义控件属性TypedArray以及attrs

    详解Android自定义控件属性TypedArray以及attrs

    这篇文章主要为大家介绍了android自定义控件属性TypedArray以及attrs,感兴趣的小伙伴们可以参考一下
    2016-01-01
  • android之listview悬浮topBar效果

    android之listview悬浮topBar效果

    这篇文章主要为大家详细介绍了android之listview悬浮topBar效果的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • Android7.0 工具类:DiffUtil详解

    Android7.0 工具类:DiffUtil详解

    这篇文章主要介绍了Android7.0 工具类:DiffUtil的相关资料,并附实例代码,和实现效果图,需要的朋友可以参考下
    2016-09-09
  • Android 中的监听和按键处理详情

    Android 中的监听和按键处理详情

    这篇文章主要介绍了Android 中的监听和按键处理详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • Android利用软引用和弱引用避免OOM的方法

    Android利用软引用和弱引用避免OOM的方法

    Java从JDK1.2版本开始,就把对象的引用分为四种级别,从而使程序能更加灵活的控制对象的生命周期。这四种级别由高到低依次为:强引用、软引用、弱引用和虚引用。本文给大家介绍Android利用软引用和弱引用避免OOM,需要的朋友一起学习吧
    2016-04-04
  • 详解Android 折叠屏适配攻略

    详解Android 折叠屏适配攻略

    这篇文章主要介绍了Android 折叠屏适配攻略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • Android动态更新Menu菜单的实现过程

    Android动态更新Menu菜单的实现过程

    菜单是用户界面中最常见的元素之一,使用非常频繁,下面这篇文章主要给大家介绍了关于Android动态更新Menu菜单的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • Kotlin Flow常见场景下的使用实例

    Kotlin Flow常见场景下的使用实例

    这篇文章主要为大家介绍了Kotlin Flow常见场景下的使用实例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • android自定义波浪加载动画的实现代码

    android自定义波浪加载动画的实现代码

    这篇文章主要为大家详细介绍了android自定义波浪加载动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Android使用SQLite数据库的简单实例

    Android使用SQLite数据库的简单实例

    这篇文章主要介绍了Android使用SQLite数据库的简单实例,有需要的朋友可以参考一下
    2013-12-12

最新评论