问题描述
因此,我正在使用以下指南来实现将fab转换为容器。这是代码。
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<com.google.android.material.circularreveal.CircularRevealFrameLayout
android:id="@+id/sheet"
android:layout_gravity="bottom|center_horizontal"
android:visibility="invisible"
android:background="@color/secondaryColor"
app:layout_behavior="com.google.android.material.transformation.FabTransformationSheetBehavior">
</com.google.android.material.circularreveal.CircularRevealFrameLayout>
<com.google.android.material.floatingactionbutton.FloatingActionButton
android:id="@+id/fab"
android:layout_gravity="bottom|end"
/>
</androidx.coordinatorlayout.widget.CoordinatorLayout>
它工作正常,但是
现在不推荐使用FabTransformationSheetBehavior
。我用谷歌搜索并想到了这个
com.google.android.material.transition.MaterialContainerTransform
现在应该代替它使用。但是当我更换它时,会出现布局膨胀错误。
无法膨胀行为子类 com.google.android.material.transition.MaterialContainerTransform
解决方法
像MaterialContainerTransform这样的外观不能在layout_behavior属性中使用。
您需要创建MaterialContainerTransform的实例,并使用一些参数对其进行初始化。
以下是对我的案例适用的示例:
MaterialContainerTransform transform = new MaterialContainerTransform();
transform.setStartView(your FAB goes here);
transform.setEndView(view which you are transitioning to);
transform.setPathMotion(new MaterialArcMotion()); //optional
transform.setScrimColor(Color.TRANSPARENT); //optional
TransitionManager.beginDelayedTransition(container,transform);
此外,使用这种方法,您实际上不再需要遵循这种布局和特定的层次结构。
以下是您可以参考的链接,以了解更多信息: https://material.io/develop/android/theming/motion