Android开发(13)——转场动画

2021-03-28  本文已影响0人  让时间走12138

本节内容

1.简介

2.overPaddingTransition动画

3.共享元素切换

4.多个共享动画

一、简介
1.在两个activity之间切换时界面的过渡效果。
2.两个activity或者Fragment之间shared elements切换效果。
3.转场动画的两种常用方式:
  • overridePendingTransition
  • ActivityOptions
二、overPaddingTransition动画
1.假如有A和B两个页面进行切换,A:从屏幕中间往左边移,直至消失。B:从右边出现,移动到屏幕中间,直至与屏幕重合。
2.新建一个anim包,在里面创建几个资源文件。
  • left_exit.xml:从左边消失的动画,移动距离为一个屏幕的宽度。所以为-100%p(相当于A页面的动画,从屏幕中消失)
<translate xmlns:android="http://schemas.android.com/apk/res/android"
     android:fromXDelta="0"
     android:toXDelta="-100%p"
     android:duration = "500"
    >
</translate>
  • left_enter.xml:从右边进入的动画。(相当于B页面的动画,从右侧进入屏幕)
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromXDelta="100%p"
    android:toXDelta="0"
    android:duration = "500"
    >
</translate>
3.任意搭建两个界面,添加两个按钮,然后修改一下背景颜色即可。先实现第一个next按钮的点击事件。
next.setOnClickListener {
     startActivity(Intent(this,DetailActivity::class.java))
     overridePendingTransition(R.anim.left_enter_anim,R.anim.left_exit_anim)
}
4.跳转过去之后,如果又要跳回去,那么在另外一个Activity里面实现一下back按钮的点击事件即可
back.setOnClickListener{
            finish()
        }
  • 如果只调用finish()函数的话,那么它只会没有任何动画效果地跳转回去,一点都不美观。
5.如果想让它也有一点动画效果,那么再添加两个资源文件即可。这一次是从右边推过去。
  • right_enter.xml:从最左边进入屏幕中间。
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromXDelta="-100%p"
    android:toXDelta="0"
    android:duration = "500">
</translate>
  • right_exit.xml:从屏幕中间移动到最右边。
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromXDelta="0"
    android:toXDelta="100%"
    android:duration = "500">
</translate>
6.在back按钮的监听事件中添加这个动画效果
overridePendingTransition(R.anim.right_enter_anim,R.anim.right_exit_anim)
7.左右都可以,那么上下切换也可以。我们添加两个从底部出现和消失的资源文件
  • bottom_enter.xml:从底部进入屏幕,这一回只用修改y坐标。
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromYDelta="100%p"
    android:toYDelta="0"
    android:duration = "500">
</translate>
  • top_exit.xml:从屏幕中向上移动,直至消失。
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromYDelta="0"
    android:toYDelta="-100%p"
    android:duration = "500">
</translate>
8.在MainActivity里面设置一下就可以使用,从另外一个页面切换回来的动画又要重新设置一下。
overridePendingTransition(R.anim.botton_enter_anim,R.anim.top_exit_anim)
9.除了推动,还可以设置透明度动画。
  • alpha_enter.xml:进入的动画。
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromAlpha="0"
    android:toAlpha="1"
    android:duration = "500">
</alpha>
  • alpha_exit.xml:消失的动画。
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromAlpha="1"
    android:toAlpha="0"
    android:duration = "500">
</alpha>
overridePendingTransition(R.anim.alpha_enter_anim,R.anim.alpha_exit_anim)
同理,缩放,旋转那些动画都是可以自己做的。
三、共享元素切换
1.界面切换时 需要有共享元素切换效果。比如A和B页面都有两张图片,那么我们想让A页面的图片和B页面的图片作为共享元素,让它们的转换更平滑一点。
  • 1.在界面A和B中 为共享控件设置相同的transitionName
android:transitionName="picture2"
  • 2.创建ActivityOptions对象
val options = ActivityOptions.makeSceneTransitionAnimation(this,imageView,"picture2")
  • 3.启动界面
startActivity(Intent(this,DetailActivity::class.java),options.toBundle())
四、多个共享动画
1.有共享元素时,切回去的方法就可以使用以下函数,这样切回去也会有一定的动画效果。
finishAfterTransition()
2.如果有多个共享元素,那么给其他元素也设置相同的transitionName,使用Pair将它们联系在一起
                val options=
                ActivityOptions.makeSceneTransitionAnimation(
                    this,
                    Pair<View,String>(imageView,"picture1"),
                    Pair<View,String>(imageView2,"picture2")
                    )
3.还有很多其他的动画,比如以下:
val options = ActivityOptions.makeScaleUpAnimation(
            imageView,0,0,imageView.width,imageView.height
4.还有其他方法来处理共享动画
         window.requestFeature(Window.FEATURE_ACTIVITY_TRANSITIONS)
        window.exitTransition = Slide(Gravity.END).setDuration(1000)
        window.enterTransition= Slide(Gravity.END).setDuration(1000)
上一篇下一篇

猜你喜欢

热点阅读