控制共享元素动画中的特定元素

Control specific elements in a shared element animation

在我的应用程序中,我有一个看起来像这样的共享元素

 <FrameLayout
    android:id="@+id/container"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">
    <TextView
        android:id="@+id/title"
        android:layout_margin="16dp"
        android:text="Title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
    <ImageView
        android:id="@+id/image"
        android:src="@drawable/hero_image"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
</FrameLayout>

在我的 activity 中,我将 image 标记为共享元素,因此图像过渡到下一个 activity。但是,我想在图像转换之前淡出 title。看起来我应该能够通过使用 setSharedElementExitTransition() 并将 title 设置为目标来实现这一点,但无论我尝试什么,该动画似乎都不起作用并且过渡图像绘制在快照上title.

我已经通读了 George Mount 的 https://halfthought.wordpress.com/2014/12/08/what-are-all-these-dang-transitions/ 并在 SO 上浏览了他的出色答案,但我只需要更多帮助 :)

假设在标题视图

上调用了 setTransitionName("text"),这是让基础工作正常进行的方法
  1. 在Activity A:

    中设置合适的共享元素退出动画
    getWindow().setSharedElementExitTransition(new TransitionSet().
                addTransition(new Fade().addTarget("text"));
    
  2. 调用 startActivity() 后,使用 setVisibility(View.INVISIBLE) 更改标题文本视图的可见性。这是使淡入淡出工作所必需的。

将视图设置为 INVISIBLE 是我缺少的基本步骤,我还设置了 window exit 动画。但是,我应该使用 Window.setReturnTransition().

设置 window return 动画