当从一个带有某个图标的界面,跳转到另一个界面中有对应这个图标的放大或者缩小版,可以考虑添加过渡动画,比较简单,几行代码即可。注意兼容性未大面积测试,但7.1.1、8.0 测试通过。
效果图如下
跳转界面
Intent intent = new Intent(ShareAActivity.this, ShareBActivity.class);
//支持多个view过渡
Pair<View, String> pImg = Pair.create(findViewById(R.id.sa_iv), "img");
Pair<View, String> pContent = Pair.create(findViewById(R.id.sa_tv), "content");
ActivityOptionsCampat compat = ActivityOptionsCompat.makeSceneTransitionAnimation(ShareAActivity.this, pImg, pContent);
startActivity(intent, compat.toBundle());
布局文件
注意需要设置对应过渡View的属性android:transitionName,源和目标的这个属性值保持相同:
源布局如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="left"
android:orientation="vertical"
android:padding="16dp">
<ImageView
android:id="@+id/sa_iv"
android:layout_width="50dp"
android:layout_height="50dp"
android:src="@mipmap/ic_launcher"
android:transitionName="img" />
<TextView
android:id="@+id/sa_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="测试"
android:textSize="16dp"
android:transitionName="content" />
</LinearLayout>
目标布局如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical">
<ImageView
android:id="@+id/sa_iv2"
android:layout_width="300dp"
android:layout_height="300dp"
android:src="@mipmap/ic_launcher"
android:transitionName="img" />
<TextView
android:id="@+id/sa_tv2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="测试"
android:textSize="25sp"
android:transitionName="content" />
</LinearLayout>