TransitionAnimation过渡动画简单实现

TransitionAnimation过渡动画实现,让交互更友好一点

当从一个带有某个图标的界面,跳转到另一个界面中有对应这个图标的放大或者缩小版,可以考虑添加过渡动画,比较简单,几行代码即可。注意兼容性未大面积测试,但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>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值