实现
从activityA到activityB
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {
ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(mActivity, imgHeart, "img_heart");
Intent intent = new Intent(mActivity, ClothesDetectActivity.class);
intent.putExtra("shoeEntity", shoeEntity);
startActivity(intent, options.toBundle());
}else {
Intent intent = new Intent(mActivity, ClothesDetectActivity.class);
intent.putExtra("shoeEntity", shoeEntity);
startActivity(intent);
}
### 从activityB返回
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
finishAfterTransition();
}else {
finish();
}
### 设置transitionName
两个页面布局中要进行动画变换的设置transitionName并取相同名字
<ImageView
android:id="@+id/img_heart"
android:transitionName="img_heart"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="@dimen/dimen_48_dip"
android:src="@drawable/icon_big_whiteheart"
tools:background="@color/main_color_green" />
### 主题设置
A页面
```
B页面
这里B页面需要设置为透明,否则可能出现闪一下黑色背景之类的情况
A页面不要设置windowExitTransition
### 多个共享的View
Pair<View, String> pair1 = new Pair<View, String>(imageView, getString(R.string.shareElement_img)); Pair<View, String> pair2 = new Pair<View, String>(textView, getString(R.string.shareElement_txt)); ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(this, pair1, pair2); startActivity(new Intent(this, TwoActivity.class),options.toBundle()); ```
相关资料
Android 5.X 提供了三种Transition类型:
进入:一个进入的过渡动画决定Activity中的素有的视图怎么进入屏幕。
退出:一个退出的过渡动画决定了一个Activity 中的所有视图怎么退出屏幕。
共享元素:一个共享元素过渡动画决定两个Activity之间的过渡,怎么共享它们的视图。
进入和退出的效果包括:
explode(分解) ———从屏幕中间进或出,移动视图。
slide(滑动)———从屏幕边缘进或出,移动视图。
fade(淡出)———通过改变屏幕上视图的不透明度达到添加或移除的效果
共享元素包括:
changeBounds———改变目标视图的布局边界
changeClipBounds———裁切目标视图边界
changeTransform———改变目标视图的缩放比例和旋转角度
changeImageTransfrom———改变目标图片的大小和缩放比例
<item name="android:windowExitTransition">@android:transition/fade </item>
<item name="android:windowExitTransition">@android:transition/explode </item>
### theme说明 ```
``` 第一个item是我们必须要设置的。接下来的6个是有规律的。前两个:指定进入和退出的动画可以重叠。中间两个:指定我们使用sharedElement时的进入和退出动画。最后两个:指定普通进入和退出的transition。这里使用的是系统自带的。不指定效果的话,系统会使用默认效果。
当然我们也能自定义效果,Android 5.0(API 级别 21)也支持这些共享元素转换:
changeBounds - 为目标视图的布局边界的变化添加动画。
changeClipBounds - 为目标视图的裁剪边界的变化添加动画。
changeTransform - 为目标视图的缩放与旋转变化添加动画。
changeImageTransform - 为目标图像的大小与缩放变化添加动画。
android:transitionName=”…“与android:transitionGroup=”true”这两个属性值。 其中第一个:在布局文件中对于要共享View添加的Flag。需要共享View的ID可以不同,但是设定的这个name需要一致。 第二个:应该将这个ViewGroup视为单个实体,也就是当成一个Transition来处理。 !
参考文章
Shared Element Activity Transition