Activity跳转动画

Activity的跳转动画在5.0的时候做了一个重大的突破,下面来看一下吧 

1.5.0之前的overridePendingTransition

相信大家对OverridePendingTransition还是很熟悉的,使用方法也是很简单就是

//fade_in是第二个界面的进入动画,fade_out是第一个界面退出动画,不想动画传入0
 overridePendingTransition(R.anim.fade_in,R.anim.fade_out);

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


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


对应动画效果

用的时候又一个缺点就是必须用在finish() 或者startActivity() 方法之后, 而此之外相对与5.0的动画,他的动画效果只在activity的界面有效果,对于其中的控件,是没有相应的效果的,

2.5.0的效果

    相对与之前的效果,5.0做了一个很大的改变,首先我们不用写xml文件了,系统直接封装好了,我们只要调用就好了,当然,由于动画没有对5.0之前做兼容,所以我们在5.0之前的手机还是要做下兼容,当然这是后话了。首先我们来看下5.0的效果

    准备工作: (针对1,2,3的操作)

        1.告诉window界面需要切换动画 有两种方式 
             a. 直接在styles.xml(21)添加<item name="android:windowContentTransitions">true</item>
             b.在 setContentView()之前加上   getWindow().requestFeature(Window.FEATURE_CONTENT_TRANSITIONS);
        2.在startActivity()界面跳转使用
            startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this).toBundle());
            到此接下来的所有操作在跳转进入的界面做操作就好了

   一.Explode 分解(有的人叫爆炸)动画  

        
        也是有2种方式实现
        1.代码  
            
          //此activity进入
          getWindow().setEnterTransition(new Explode().setDuration(2000));
          //此activity退出
          getWindow().setExitTransition(new Explode().setDuration(2000));

          //再次进入时使用(如果当前Activity已经打开过,并且再次打开该Activity时的动画 )
          //getWindow().setReenterTransition(new Explode().setDuration(2000));
          //决定在两个Activity之间切换时,指定两个Activity中对应的View的过渡效果
          // getWindow().setSharedElementEnterTransition(new Explode().setDuration(2000));

          2.explode写入 res/transition文件夹下的xml中
<explode xmlns:android="http://schemas.android.com/apk/res/android"

   android:duration="2000"
 />

                 a.  然后通过                     
Transition explode = TransitionInflater.from(this).inflateTransition(R.transition.explode);
getWindow().setEnterTransition(explode);
getWindow().setExitTransition(explode);

                b.也可以在主题中配置                      
<item name="android:windowExitTransition">@transition/explode</item> 
<item name="android:windowEnterAnimation">@transition/explode</item> 
<item name="android:windowReenterTransition">@transition/explode</item>

      二  Fade  淡入淡出 

               

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

      三 Slide 滑动进入       

   

 //左侧滑入
 getWindow().setEnterTransition(new Slide(Gravity.LEFT).setDuration(2000));
 getWindow().setExitTransition(new Slide(Gravity.RIGHT).setDuration(2000));

              b .xml中的话
                
<?xml version="1.0" encoding="utf-8"?>
<!--slideEdge表示起始滑动的侧边位置,end表示右侧,start表示左侧,top表示顶部,bottom表示底侧-->
<slide xmlns:android="http://schemas.android.com/apk/res/android"
       android:duration="2000"
       android:slideEdge="end">
    <!--去掉顶部状态栏,底部操作栏的滑动-->
    <targets>
        <target android:excludeId="@android:id/navigationBarBackground" />
        <target android:excludeId="@android:id/statusBarBackground" />
    </targets>
    
</slide>



       
         

        5.0的共享元素动画


            1.系统自带的
            a.一个共享View
           首先用到的activity的跳转方法是(一个共享view的):
              
startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this,button,"all_hava").toBundle());

            说下参数 button表示这个共享的view,后面的字符串 “all_hava”是两个共享view在xml中的  android:transitionName="all_hava"
                用到的就是这些,是不是很简单 
               b.多个 共享view 
                    这里我们稍稍看下源码 makeSceneTransitionAnimation(Activity activity,   Pair<View, String>... sharedElements),知道可以利用Pair来传参数  ,格式如下,不多说了
                startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this,
                                                create(((View) button),"all_hava"), 
                                                create(((View) textView),"all_hava"))
                                               .toBundle())
            系统自带的差不多已经够用了,如果我们要玩点自定义的呢
             
剩下的在来说下兼容问题,因为只有5.0以上才有上面的这些个动画,所以,我们肯定是要做兼容的 首先肯定是要加判断的
    if (Build.VERSION. SDK_INT >= Build.VERSION_CODES. LOLLIPOP ){

startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this,button,"all_hava").toBundle());

}else{

a. //低版本兼容,不过没动画效果 http://www.cnblogs.com/tianzhijiexian/p/4087917.html 可以看下这个介绍
ActivityOptionsCompat optionsCompat = ActivityOptionsCompat.makeScaleUpAnimation(
button,
0,
0,
0,
0);
ActivityCompat.startActivity(this,intent,optionsCompat.toBundle());

b. //或者是直接用overridePendingTransition();
}




兼容5.0以下的转场动画   
可以看下http://www.jianshu.com/p/340c938e9f32 (翻译版)
https://medium.com/@aitorvs/android-shared-element-transitions-for-all-b90e9361507d(原文版)










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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值