android 5.x—过渡动画Transition

android 5.x 提供了3中过渡动画:

  • 进入:一个进入的过渡(动画)决定activity中的所有的视图怎么进入屏幕
  • 退出:一个退出的过渡(动画)决定一个activity中的所有视图怎么退出屏幕。
  • 共享元素:一个共享元素过渡(动画)决定两个activities之间的过渡,怎么共享(它们)的视图

有以下进入和退出的过渡动画:

  • explode(分解)—— 进入/退出从屏幕中间移动视图;
  • slide(滑动)——进入/退出从屏幕边沿石洞视图;
  • fade(淡出)——通过改变屏幕上视图的不透明度达到进入/退出视图的效果

在以上动画基础上还可以添加共享元素过渡,共享元素的效果,是基于分解动画基础上进行的,共享元素过渡是共享2个activity中共同的元素,在页面切换过程中,共享元素仿佛独立于2个activity页面,效果如下:

共享元素支持如下效果:

  • changeBounds——改变目标视图的布局界面;
  • changeClipBounds——裁剪目标视图边界;
  • changeTransform——改变目标视图的缩放比例和旋转角度;
  • changeImageTransform——改变目标图片的大小和缩放比例

android 5.x—过渡动画Transition_第1张图片

上面这张图能让大家理解共享元素过渡。Activity 1和Activity 2中的android机器人是设置的共同共享元素,Activity 1跳转到Activity 2的过程中,android机器人经过平移,缩放,最终达到了Activity 2的效果。

过渡动画使用:

1、在要使用过渡动画的activity中添加:

// 允许使用transitions,需要放在setContentView之前  
getWindow().requestFeature(Window.FEATURE_CONTENT_TRANSITIONS); 

或者在布局样式中添加:

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

2、不同的动画效果:

  • 进入动画
getWindow().setEnterTransition(new Explode());
getWindow().setEnterTransition(new Slide());
getWindow().setEnterTransition(new Fade());
  • 退出动画
getWindow().setExitTransition(new Explode());
getWindow().setExitTransition(new Slide());
getWindow().setExitTransition(new Fade());

3、activity跳转启动动画效果:

startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this).toBundle());

4、设置共享元素动画:

  • 使用android:transitionName属性给两个布局中的共享元素指定一个相同的名字(名字一定是相同的)

activity 1中定义的共享元素

<ImageView  android:id="@+id/iv_shared_img" android:layout_width="10dp" android:layout_height="10dp" android:scaleType="centerInside" android:src="@drawable/sun" android:padding="10dp" android:transitionName="sun" android:layout_margin="10dp" android:textSize="15sp"/>
    <ImageView  android:transitionName="sheep" android:id="@+id/iv_sheep_img" android:layout_width="10dp" android:layout_height="10dp" android:scaleType="centerInside" android:src="@drawable/sheep" android:padding="10dp" android:layout_margin="10dp" android:textSize="15sp"/>

activity 2中的定义的共享元素

<ImageView  android:id="@+id/iv_shared_img" android:layout_width="100dp" android:layout_height="100dp" android:layout_alignParentRight="true" android:layout_gravity="right" android:layout_margin="10dp" android:layout_marginRight="20dp" android:padding="10dp" android:scaleType="centerInside" android:src="@drawable/sun" android:textSize="15sp" android:transitionName="sun"/>


    <ImageView  android:id="@+id/iv_sheep_img" android:layout_width="100dp" android:layout_height="100dp" android:layout_alignParentBottom="true" android:layout_alignParentRight="true" android:layout_margin="10dp" android:layout_marginBottom="40dp" android:layout_marginRight="40dp" android:padding="10dp" android:scaleType="centerInside" android:src="@drawable/sheep" android:textSize="15sp" android:transitionName="sheep"/>
  • 使用ActivityOptions.makeSceneTransitionAnimation() 方法启动共享动画

如果只有一个共享元素,则使用

startActivity(intent, ActivityOptions.makeSceneTransitionAnimation(mAty, Pair.create((View) mIv_sun_img, "sun")).toBundle());

Pair.create(View,String)中第一个参数是共享元素的View对象,第二个参数是绑定的的android:transitionName属性值。

如果是多个共享元素,如下代码使用

startActivity(intent, ActivityOptions.makeSceneTransitionAnimation(mAty, Pair.create((View) mIv_sun_img, "sun"),Pair.create(mv_sheep,"sheep")).toBundle());

demo下载地址

你可能感兴趣的:(android,transition,过渡动画)