我有一个支持CoordinatorLayout的FloatingActionButton,我想在其中显示Snackbar ..
android:id="@+id/rootView"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
android:layout_width="match_parent"
android:layout_height="match_parent">
...
android:id="@+id/fab_add_field"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end|bottom"
android:layout_margin="@dimen/margin_default"
android:layout_marginBottom="@dimen/profile_floating_margin_bottom"
android:layout_marginRight="@dimen/profile_floating_margin_right"
android:clickable="true"
android:src="@drawable/icon_plus"
app:backgroundTint="@color/brand_green"
app:borderWidth="0dp"
app:elevation="@dimen/fac_icon_elevation"/>
现在,我正在显示像这样的 snackbar
Snackbar.make(mRootView, "Something went wrong", Snackbar.LENGHT_SHORT)
.show();
显示时,FAB向上滑动,当它消失后(在LENGHT_SHORT之后),FAB向下滑动,一切正常。
但是,如果我将Snackbar滑动了一下,FAB将向下移动而没有幻灯片动画。它只是闪烁到其初始位置。
有趣的是,如果Snackbar有两行(无论是否有 Action )并被扫除,则FAB会使用通常的幻灯片动画正确地动画回到其位置。
那是android.support.design.widget.CoordinatorLayout中的错误吗
或android.support.design.widget.FloatingActionButton?任何解决方法?
最佳答案
Kotlin解决方案,不使用基于Matteo Destro's post的ValueAnimator:class SnackBarAwareBehavior : CoordinatorLayout.Behavior {
companion object {
private const val DURATION = 180
}
constructor() : super() {}
constructor(context: Context, attrs: AttributeSet) : super(context, attrs) {}
override fun layoutDependsOn(
parent: CoordinatorLayout,
child: View,
dependency: View
): Boolean {
return dependency is Snackbar.SnackbarLayout
}
override fun onDependentViewChanged(
parent: CoordinatorLayout,
child: View,
dependency: View
): Boolean {
if (dependency.visibility == View.VISIBLE) {
moveChildUp(child, dependency.height + dependency.marginBottom)
return true
}
return false
}
override fun onDependentViewRemoved(parent: CoordinatorLayout, child: View, dependency: View) {
moveChildToInitialPosition(child)
}
private fun moveChildUp(child: View, translation: Int) {
child.animate()
.translationY((-translation).toFloat())
.setInterpolator(DecelerateInterpolator())
.setDuration(DURATION.toLong())
.start()
}
private fun moveChildToInitialPosition(child: View) {
child.animate()
.translationY(0f)
.setInterpolator(AccelerateInterpolator())
.setDuration(DURATION.toLong())
.start()
}
}