两个活动之间的Android共享元素转换不起作用

Kir*_*rov 20 android floating-action-button android-design-library

在我的应用程序中,我正在尝试使用新引入的活动之间的元素共享.如果共享元素具有固定位置(例如android:layout_gravity="top"),则一切都像魅力一样,但是当视图锚定时问题就出现了.

我的第一个活动看起来像这样:

<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/tools"
    xmlns:auto="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        ...
    </android.support.design.widget.AppBarLayout>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/play_all"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|right"
        android:layout_margin="24dp"/>

</android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)

我的第二项活动是这样的

<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:auto="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/list"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/play"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="16dp"
        android:elevation="10dp"
        android:src="@drawable/ic_action_play"
        auto:layout_anchor="@+id/appbar"
        android:transitionName="fab_button"
        auto:layout_anchorGravity="bottom|right" />

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="192dp">
        ...
    </android.support.design.widget.AppBarLayout>

    ...

</android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)

我使用的代码如下:

Intent intent = ...;
ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(this, view, "fab_button");
startActivity(intent, options.toBundle());
Run Code Online (Sandbox Code Playgroud)

如果我使用layout_anchorlayout_anchorGravity属性,两个FAB之间的过渡完成没有动画.如果第二个FAB具有固定位置,则它可以完美地工作.我究竟做错了什么?

小智 16

这可能有点晚了,但我找到了绕过这个问题的方法.您必须将共享元素包装到布局中,并将锚点放在该布局上:

<FrameLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        auto:layout_anchor="@+id/appbar"
        auto:layout_anchorGravity="bottom|right">

    <android.support.design.widget.FloatingActionButton
            android:id="@+id/play"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="16dp"
            android:elevation="10dp"
            android:src="@drawable/ic_action_play"
            android:transitionName="fab_button" />

<FrameLayout/>
Run Code Online (Sandbox Code Playgroud)


Pra*_*ani 1

活动共享元素转换:

按照步骤。

  1. 启用窗口内容转换
  2. 分配通用转换名称
  3. 开始活动
  4. 多个共享元素
  5. 自定义共享元素转换

我认为你没有遵循第二步。您已android:transitionName="fab_button"在 Second 中给出Activity,但在 First 中未给出Activity

XML第一个Activity(添加android:transitionName="fab_button"):

<android.support.design.widget.FloatingActionButton

        android:transitionName="fab_button"

        android:id="@+id/play_all"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|right"
        android:layout_margin="24dp"/>
Run Code Online (Sandbox Code Playgroud)

也许上面的链接会对您有所帮助。

  • 不,不是这样的。第一个活动视图是图像视图,目标是锚定的 FAB。如果我将目标 FAB 设置为非锚定,则一切正常。 (2认同)