mit*_*m93 5 android transitions
在活动转换期间,我无法将视图保持在顶部。卡片左侧的图片是一个共享元素,它扩展到第二个活动的一半,我有一个从底部滑入的 FAB。我将饮料的 ImageView 作为共享元素过渡,而 FAB 是从底部开始的幻灯片过渡。
在 FAB 的幻灯片动画期间,它停留在 ImageView 下方,如您在第二张图片中所见。然而,在它完成动画后,它会弹出 ImageView 的顶部,如您在第三张图片中看到的那样。我在退出转换过程中遇到了同样的问题,当它开始滑动时它会立即弹出 ImageView 下方。
我希望 FAB 在整个过程中始终处于 ImageView 之上,我该如何实施?
主要活动:
FAB还在滑动时的次要Activity:

FAB 滑动完成后的次要 Activity:

次要活动的 XML 文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/drinkImage"
android:layout_width="match_parent"
android:layout_height="300dp"
android:adjustViewBounds="true"
android:scaleType="centerCrop"
android:gravity="start"
android:transitionName="@string/drink_image_transition"
/>
<TextView
android:padding="8dp"
android:id="@+id/drinkName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:translationY="@dimen/detail_drink_name_vertical_offset"
android:textSize="24sp"
android:textColor="@color/text_primary"
android:transitionName="@string/drink_name_transition"
/>
<ImageButton
android:id="@+id/fab"
android:layout_width="@dimen/fab_size_normal"
android:layout_height="@dimen/fab_size_normal"
android:layout_margin="@dimen/add_button_margin"
android:translationX="@dimen/detail_fab_horizontal_offset"
android:translationY="@dimen/detail_fab_vertical_offset"
android:background="@drawable/fab_shape"
android:elevation="@dimen/elevation_low"
android:src="@drawable/fab_ic_add"
android:stateListAnimator="@anim/button_elevation"
android:transitionName="fab_transition"
/>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
次要活动的 onCreate() 方法:
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.details_drink);
//grab Drink parcel
Drink d = getIntent().getParcelableExtra("drink");
//set up image
ImageView i = (ImageView) findViewById(R.id.drinkImage);
i.setImageDrawable(this.getResources().getDrawable(d.getImageResourceID(this)));
//set up text
TextView t = (TextView) findViewById(R.id.drinkName);
t.setText(d.name);
Transition ts = new Slide();
//don't want status bar and navigation bar to slide across screen
ts.excludeTarget(android.R.id.statusBarBackground, true);
ts.excludeTarget(android.R.id.navigationBarBackground, true);
ts.setDuration(3000);
getWindow().setEnterTransition(ts);
getWindow().setExitTransition(ts);
//This line gets it to work! As Pavel suggested
//getWindow().setSharedElementsUseOverlay(false);
}
Run Code Online (Sandbox Code Playgroud)
默认情况下,Android 使用ViewOverlay进行 Activity 转换。这就是为什么共享元素被绘制在其他元素之上。
您可以通过调用getWindow().setSharedElementsUseOverlay(false);来禁用此功能。在开始过渡之前。这应该告诉 Android 在动画期间使用原始视图层次结构
| 归档时间: |
|
| 查看次数: |
1635 次 |
| 最近记录: |